diff options
| author | Stephen Blott | 2015-09-19 12:05:24 +0100 | 
|---|---|---|
| committer | Stephen Blott | 2015-09-19 12:05:24 +0100 | 
| commit | 2eb6d9a7d3412e4b46e081caa7054f925ffe7e92 (patch) | |
| tree | a490b2fdc3740898e7de48ea52c27430fe6ebc20 | |
| parent | 2c6d67c05b6ef57aabda288a164dd2885894ae89 (diff) | |
| download | vimium-2eb6d9a7d3412e4b46e081caa7054f925ffe7e92.tar.bz2 | |
Tidy up #1833.
| -rw-r--r-- | content_scripts/ui_component.coffee | 25 | 
1 files changed, 15 insertions, 10 deletions
| diff --git a/content_scripts/ui_component.coffee b/content_scripts/ui_component.coffee index 2218c3c7..72627f69 100644 --- a/content_scripts/ui_component.coffee +++ b/content_scripts/ui_component.coffee @@ -12,7 +12,7 @@ class UIComponent      # Default to everything hidden while the stylesheet loads.      styleSheet.innerHTML = "iframe {display: none;}" -    UIComponent::styleSheetGetter ?= new AsyncDataFetcher @fetchStyles +    UIComponent::styleSheetGetter ?= new AsyncDataFetcher @fetchFileContents "content_scripts/vimium.css"      @styleSheetGetter.use (styles) -> styleSheet.innerHTML = styles      @iframeElement = DomUtils.createElement "iframe" @@ -116,21 +116,26 @@ class UIComponent              window.removeEventListener "focus", handler              refocusSourceFrame() -  fetchStyles: (callback) -> -    stylesheetRequest = new XMLHttpRequest() +  # Fetch a Vimium file/resource (such as "content_scripts/vimium.css"). +  # We try making an XMLHttpRequest request.  That can fail (see #1817), in which case we fetch the +  # file/resource via the background page. +  fetchFileContents: (file) -> (callback) -> +    request = new XMLHttpRequest() -    stylesheetRequest.onload = -> -      return stylesheetRequest.onerror() unless stylesheetRequest.status == 200 -      callback stylesheetRequest.responseText +    request.onload = -> +      if request.status == 200 +        callback request.responseText +      else +        request.onerror() -    stylesheetRequest.onerror = -> +    request.onerror = ->        chrome.runtime.sendMessage          handler: "fetchFileContents" -        fileName: "content_scripts/vimium.css" +        fileName: file        , callback -    stylesheetRequest.open "GET", (chrome.runtime.getURL "content_scripts/vimium.css"), true -    stylesheetRequest.send() +    request.open "GET", (chrome.runtime.getURL file), true +    request.send()  root = exports ? window | 
