Merge pull request #1782 from overleaf/pr-as-ace-diagnostics

Ace diagnosis

GitOrigin-RevId: 5a4c1d49887594686f810fedc06266bdbb7175c5
This commit is contained in:
Alasdair Smith 2019-05-17 09:44:49 +01:00 committed by sharelatex
parent e06a68ace6
commit 1ec05a0fab

View file

@ -36,6 +36,22 @@
(function() { (function() {
window.__log__measurements_ace_ = function () {
var aceEditor = document.querySelector('#editor .ace_editor');
var aceScroller = document.querySelector('#editor .ace_scroller');
var aceContent = document.querySelector('#editor .ace_content');
if (aceEditor) {
console.log("aceEditor", aceEditor.getBoundingClientRect(), aceEditor.offsetParent);
}
if (aceScroller) {
console.log("aceScroller", aceScroller.getBoundingClientRect(), aceScroller.offsetParent);
}
if (aceContent) {
console.log("aceContent", aceContent.getBoundingClientRect(), aceContent.offsetParent);
}
}
var ACE_NAMESPACE = "ace"; var ACE_NAMESPACE = "ace";
var global = (function() { return this; })(); var global = (function() { return this; })();
@ -15190,6 +15206,8 @@ var Lines = function(element, canvasHeight) {
(function() { (function() {
this.moveContainer = function(config) { this.moveContainer = function(config) {
console.log("this.moveContainer", this.element.className, 0, -((config.firstRowScreen * config.lineHeight) % this.canvasHeight) - config.offset * this.$offsetCoefficient);
__log__measurements_ace_();
dom.translate(this.element, 0, -((config.firstRowScreen * config.lineHeight) % this.canvasHeight) - config.offset * this.$offsetCoefficient); dom.translate(this.element, 0, -((config.firstRowScreen * config.lineHeight) % this.canvasHeight) - config.offset * this.$offsetCoefficient);
}; };
@ -16732,6 +16750,8 @@ var Cursor = function(parentEl) {
dom.setStyle(style, "display", "none"); dom.setStyle(style, "display", "none");
} else { } else {
dom.setStyle(style, "display", "block"); dom.setStyle(style, "display", "block");
console.log("this.update", element.className, pixelPos.left, pixelPos.top);
__log__measurements_ace_();
dom.translate(element, pixelPos.left, pixelPos.top); dom.translate(element, pixelPos.left, pixelPos.top);
dom.setStyle(style, "width", Math.round(config.characterWidth) + "px"); dom.setStyle(style, "width", Math.round(config.characterWidth) + "px");
dom.setStyle(style, "height", config.lineHeight + "px"); dom.setStyle(style, "height", config.lineHeight + "px");
@ -17217,7 +17237,6 @@ cursor: text;\
position: absolute;\ position: absolute;\
box-sizing: border-box;\ box-sizing: border-box;\
min-width: 100%;\ min-width: 100%;\
contain: style size layout;\
}\ }\
.ace_dragging .ace_scroller:before{\ .ace_dragging .ace_scroller:before{\
position: absolute;\ position: absolute;\
@ -17248,7 +17267,6 @@ z-index: 4;\
-moz-user-select: none;\ -moz-user-select: none;\
-webkit-user-select: none;\ -webkit-user-select: none;\
user-select: none;\ user-select: none;\
contain: style size layout;\
}\ }\
.ace_gutter-active-line {\ .ace_gutter-active-line {\
position: absolute;\ position: absolute;\
@ -17284,7 +17302,6 @@ background-position: 2px center;\
background-image: url(\"\");\ background-image: url(\"\");\
}\ }\
.ace_scrollbar {\ .ace_scrollbar {\
contain: strict;\
position: absolute;\ position: absolute;\
right: 0;\ right: 0;\
bottom: 0;\ bottom: 0;\
@ -17326,7 +17343,6 @@ overflow: hidden;\
font: inherit;\ font: inherit;\
padding: 0 1px;\ padding: 0 1px;\
margin: 0 -1px;\ margin: 0 -1px;\
contain: strict;\
-ms-user-select: text;\ -ms-user-select: text;\
-moz-user-select: text;\ -moz-user-select: text;\
-webkit-user-select: text;\ -webkit-user-select: text;\
@ -17352,7 +17368,6 @@ filter: none!important;\
perspective: none!important;\ perspective: none!important;\
clip-path: none!important;\ clip-path: none!important;\
mask : none!important;\ mask : none!important;\
contain: none!important;\
perspective: none!important;\ perspective: none!important;\
mix-blend-mode: initial!important;\ mix-blend-mode: initial!important;\
z-index: auto;\ z-index: auto;\
@ -17374,17 +17389,14 @@ width: auto;\
text-align: right;\ text-align: right;\
pointer-events: auto;\ pointer-events: auto;\
height: 1000000px;\ height: 1000000px;\
contain: style size layout;\
}\ }\
.ace_text-layer {\ .ace_text-layer {\
font: inherit !important;\ font: inherit !important;\
position: absolute;\ position: absolute;\
height: 1000000px;\ height: 1000000px;\
width: 1000000px;\ width: 1000000px;\
contain: style size layout;\
}\ }\
.ace_text-layer > .ace_line, .ace_text-layer > .ace_line_group {\ .ace_text-layer > .ace_line, .ace_text-layer > .ace_line_group {\
contain: style size layout;\
position: absolute;\ position: absolute;\
top: 0;\ top: 0;\
left: 0;\ left: 0;\
@ -17394,12 +17406,10 @@ right: 0;\
.ace_hidpi .ace_gutter-layer,\ .ace_hidpi .ace_gutter-layer,\
.ace_hidpi .ace_content,\ .ace_hidpi .ace_content,\
.ace_hidpi .ace_gutter {\ .ace_hidpi .ace_gutter {\
contain: strict;\
will-change: transform;\ will-change: transform;\
}\ }\
.ace_hidpi .ace_text-layer > .ace_line, \ .ace_hidpi .ace_text-layer > .ace_line, \
.ace_hidpi .ace_text-layer > .ace_line_group {\ .ace_hidpi .ace_text-layer > .ace_line_group {\
contain: strict;\
}\ }\
.ace_cjk {\ .ace_cjk {\
display: inline-block;\ display: inline-block;\
@ -18045,6 +18055,8 @@ var VirtualRenderer = function(container, theme) {
this.$moveTextAreaToCursor = function() { this.$moveTextAreaToCursor = function() {
var style = this.textarea.style; var style = this.textarea.style;
if (!this.$keepTextAreaAtCursor) { if (!this.$keepTextAreaAtCursor) {
console.log("this.$moveTextAreaToCursor-$keepTextAreaAtCursor", this.textarea.className, -100, 0);
__log__measurements_ace_();
dom.translate(this.textarea, -100, 0); dom.translate(this.textarea, -100, 0);
return; return;
} }
@ -18062,6 +18074,8 @@ var VirtualRenderer = function(container, theme) {
var h = composition && composition.useTextareaForIME ? this.lineHeight : HIDE_TEXTAREA ? 0 : 1; var h = composition && composition.useTextareaForIME ? this.lineHeight : HIDE_TEXTAREA ? 0 : 1;
if (posTop < 0 || posTop > config.height - h) { if (posTop < 0 || posTop > config.height - h) {
console.log("this.$moveTextAreaToCursor-if postop...", this.textarea.className, 0, 0);
__log__measurements_ace_();
dom.translate(this.textarea, 0, 0); dom.translate(this.textarea, 0, 0);
return; return;
} }
@ -18089,6 +18103,8 @@ var VirtualRenderer = function(container, theme) {
dom.setStyle(style, "height", h + "px"); dom.setStyle(style, "height", h + "px");
dom.setStyle(style, "width", w + "px"); dom.setStyle(style, "width", w + "px");
console.log("this.$moveTextAreaToCursor-last one", this.textarea.className, Math.min(posLeft, this.$size.scrollerWidth - w), Math.min(posTop, this.$size.height - h));
__log__measurements_ace_();
dom.translate(this.textarea, Math.min(posLeft, this.$size.scrollerWidth - w), Math.min(posTop, this.$size.height - h)); dom.translate(this.textarea, Math.min(posLeft, this.$size.scrollerWidth - w), Math.min(posTop, this.$size.height - h));
}; };
this.getFirstVisibleRow = function() { this.getFirstVisibleRow = function() {
@ -18228,6 +18244,8 @@ var VirtualRenderer = function(container, theme) {
if (changes & this.CHANGE_H_SCROLL) if (changes & this.CHANGE_H_SCROLL)
this.$updateScrollBarH(); this.$updateScrollBarH();
console.log("this.$renderChanges", this.content.className, -this.scrollLeft, -config.offset);
__log__measurements_ace_();
dom.translate(this.content, -this.scrollLeft, -config.offset); dom.translate(this.content, -this.scrollLeft, -config.offset);
var width = config.width + 2 * this.$padding + "px"; var width = config.width + 2 * this.$padding + "px";
@ -18237,6 +18255,8 @@ var VirtualRenderer = function(container, theme) {
dom.setStyle(this.content.style, "height", height); dom.setStyle(this.content.style, "height", height);
} }
if (changes & this.CHANGE_H_SCROLL) { if (changes & this.CHANGE_H_SCROLL) {
console.log("this.$renderChanges-if changes", this.content.className, -this.scrollLeft, -config.offset);
__log__measurements_ace_();
dom.translate(this.content, -this.scrollLeft, -config.offset); dom.translate(this.content, -this.scrollLeft, -config.offset);
this.scroller.className = this.scrollLeft <= 0 ? "ace_scroller" : "ace_scroller ace_scroll-left"; this.scroller.className = this.scrollLeft <= 0 ? "ace_scroller" : "ace_scroller ace_scroll-left";
} }