mediawiki-extensions-Visual.../modules/ve/ce/ve.ce.DomRange.js
Inez Korczyński b98ee5140a DomRange makes more sense as a name for this class (cause it is not rangy specific).
Change-Id: I670523a0ed2216ebe34dc4b759a4aa429b9da53c
2013-03-05 12:18:59 -08:00

49 lines
1.3 KiB
JavaScript

/*!
* VisualEditor DomRange class.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/**
* DomRange.
*
* @class
* @constructor
* @param {HTMLElement} focusNode Selection focus node
* @param {number} focusOffset Selection focus offset
* @param {HTMLElement} anchorNode Selection anchor node
* @param {number} anchorOffset Selection anchor offset
*/
ve.ce.DomRange = function VeCeDomRange( focusNode, focusOffset, anchorNode, anchorOffset ) {
this.focusNode = focusNode;
this.focusOffset = focusOffset;
this.anchorNode = anchorNode;
this.anchorOffset = anchorOffset;
};
/* Static Methods */
ve.ce.DomRange.newFromDomSelection = function ( selection ) {
return new ve.ce.DomRange(
selection.focusNode, selection.focusOffset, selection.anchorNode, selection.anchorOffset
);
};
/* Methods */
ve.ce.DomRange.prototype.equals = function ( other ) {
return other &&
this.focusNode === other.focusNode &&
this.focusOffset === other.focusOffset &&
this.anchorNode === other.anchorNode &&
this.anchorOffset === other.anchorOffset;
};
ve.ce.DomRange.prototype.getRange = function () {
return new ve.Range(
ve.ce.getOffset( this.anchorNode, this.anchorOffset ),
ve.ce.getOffset( this.focusNode, this.focusOffset )
);
};