diff --git a/spec/text-editor-component-spec.coffee b/spec/text-editor-component-spec.coffee index 6c4b365d6..7e0810ceb 100644 --- a/spec/text-editor-component-spec.coffee +++ b/spec/text-editor-component-spec.coffee @@ -1908,7 +1908,8 @@ describe "TextEditorComponent", -> } """, context: 'atom-text-editor' - nextAnimationFrame() + nextAnimationFrame() # handle stylesheet change event + nextAnimationFrame() # perform requested update scrollbarCornerNode = componentNode.querySelector('.scrollbar-corner') expect(verticalScrollbarNode.offsetWidth).toBe 8 diff --git a/src/text-editor-component.coffee b/src/text-editor-component.coffee index 7e94deebd..616770452 100644 --- a/src/text-editor-component.coffee +++ b/src/text-editor-component.coffee @@ -664,8 +664,13 @@ TextEditorComponent = React.createClass onStylesheetsChanged: (styleElement) -> return unless @performedInitialMeasurement return unless atom.themes.isInitialLoadComplete() - @refreshScrollbars() if not styleElement.sheet? or @containsScrollbarSelector(styleElement.sheet) - @handleStylingChange() + + # This delay prevents the styling from going haywire when stylesheets are + # reloaded in dev mode. It seems like a workaround for a browser bug, but + # not totally sure. + requestAnimationFrame => + @refreshScrollbars() if not styleElement.sheet? or @containsScrollbarSelector(styleElement.sheet) + @handleStylingChange() onAllThemesLoaded: -> @refreshScrollbars()