From a3765d97853ecfe3fa608cd3b191a33cabe311ec Mon Sep 17 00:00:00 2001 From: Dan Bornstein Date: Tue, 30 Aug 2016 11:10:17 -0700 Subject: [PATCH] Account for any top margin on the first line. Without this change, a top margin on any element on the first line of pad content would throw off the alignment of line numbers. The default stylesheet doesn't define any elements with top margins, but plugins might. (This is also explained in a code comment.) In order to see the problem, add the following clause to `iframe_editor.css` (before incorporating this commit): #innerdocbody > :first-child { margin-top: 100px; } --- src/static/js/ace2_inner.js | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/static/js/ace2_inner.js b/src/static/js/ace2_inner.js index def7b0900..0970666eb 100644 --- a/src/static/js/ace2_inner.js +++ b/src/static/js/ace2_inner.js @@ -5459,7 +5459,16 @@ function Ace2Inner(){ // and the line-numbers don't line up unless we pay // attention to where the divs are actually placed... // (also: padding on TTs/SPANs in IE...) - h = b.nextSibling.offsetTop - b.offsetTop; + if (b === doc.body.firstChild) { + // It's the first line. For line number alignment purposes, its + // height is taken to be the top offset of the next line. If we + // didn't do this special case, we would miss out on any top margin + // included on the first line. The default stylesheet doesn't add + // extra margins, but plugins might. + h = b.nextSibling.offsetTop; + } else { + h = b.nextSibling.offsetTop - b.offsetTop; + } } if (h) {