css_loader.ts 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. ///<reference path="../../headers/common.d.ts" />
  2. var waitSeconds = 100;
  3. var head = document.getElementsByTagName("head")[0];
  4. // get all link tags in the page
  5. var links = document.getElementsByTagName("link");
  6. var linkHrefs = [];
  7. for (var i = 0; i < links.length; i++) {
  8. linkHrefs.push(links[i].href);
  9. }
  10. var isWebkit = !!window.navigator.userAgent.match(/AppleWebKit\/([^ ;]*)/);
  11. var webkitLoadCheck = function(link, callback) {
  12. setTimeout(function() {
  13. for (var i = 0; i < document.styleSheets.length; i++) {
  14. var sheet = document.styleSheets[i];
  15. if (sheet.href === link.href) {
  16. return callback();
  17. }
  18. }
  19. webkitLoadCheck(link, callback);
  20. }, 10);
  21. };
  22. var noop = function() {};
  23. var loadCSS = function(url) {
  24. return new Promise(function(resolve, reject) {
  25. var link = document.createElement("link");
  26. var timeout = setTimeout(function() {
  27. reject("Unable to load CSS");
  28. }, waitSeconds * 1000);
  29. var _callback = function(error) {
  30. clearTimeout(timeout);
  31. link.onload = link.onerror = noop;
  32. setTimeout(function() {
  33. if (error) {
  34. reject(error);
  35. } else {
  36. resolve("");
  37. }
  38. }, 7);
  39. };
  40. link.type = "text/css";
  41. link.rel = "stylesheet";
  42. link.href = url;
  43. if (!isWebkit) {
  44. link.onload = function() {
  45. _callback(undefined);
  46. };
  47. } else {
  48. webkitLoadCheck(link, _callback);
  49. }
  50. link.onerror = function(evt: any) {
  51. _callback(evt.error || new Error("Error loading CSS file."));
  52. };
  53. head.appendChild(link);
  54. });
  55. };
  56. export function fetch(load): any {
  57. if (typeof window === "undefined") {
  58. return "";
  59. }
  60. // dont reload styles loaded in the head
  61. for (var i = 0; i < linkHrefs.length; i++) {
  62. if (load.address === linkHrefs[i]) {
  63. return "";
  64. }
  65. }
  66. return loadCSS(load.address);
  67. }