index.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. // Version
  2. var Versions = {
  3. "Latest": [
  4. "https://preview.babylonjs.com/babylon.js",
  5. "https://preview.babylonjs.com/gui/babylon.gui.min.js",
  6. "https://preview.babylonjs.com/inspector/babylon.inspector.bundle.js",
  7. "https://preview.babylonjs.com/nodeEditor/babylon.nodeEditor.js",
  8. "https://preview.babylonjs.com/materialsLibrary/babylonjs.materials.min.js",
  9. "https://preview.babylonjs.com/proceduralTexturesLibrary/babylonjs.proceduralTextures.min.js",
  10. "https://preview.babylonjs.com/postProcessesLibrary/babylonjs.postProcess.min.js",
  11. "https://preview.babylonjs.com/loaders/babylonjs.loaders.min.js",
  12. "https://preview.babylonjs.com/serializers/babylonjs.serializers.min.js"
  13. ],
  14. "4.2.0": [
  15. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/babylon.js",
  16. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/gui/babylon.gui.min.js",
  17. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/inspector/babylon.inspector.bundle.js",
  18. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/materialsLibrary/babylonjs.materials.min.js",
  19. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/proceduralTexturesLibrary/babylonjs.proceduralTextures.min.js",
  20. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/postProcessesLibrary/babylonjs.postProcess.min.js",
  21. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/loaders/babylonjs.loaders.min.js",
  22. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.2.0/dist/serializers/babylonjs.serializers.min.js"
  23. ],
  24. "4.1.0": [
  25. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/babylon.js",
  26. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/gui/babylon.gui.min.js",
  27. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/inspector/babylon.inspector.bundle.js",
  28. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/materialsLibrary/babylonjs.materials.min.js",
  29. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/proceduralTexturesLibrary/babylonjs.proceduralTextures.min.js",
  30. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/postProcessesLibrary/babylonjs.postProcess.min.js",
  31. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/loaders/babylonjs.loaders.min.js",
  32. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.1.0/dist/serializers/babylonjs.serializers.min.js"
  33. ],
  34. "4.0.3": [
  35. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/babylon.js",
  36. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/gui/babylon.gui.min.js",
  37. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/inspector/babylon.inspector.bundle.js",
  38. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/materialsLibrary/babylonjs.materials.min.js",
  39. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/proceduralTexturesLibrary/babylonjs.proceduralTextures.min.js",
  40. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/postProcessesLibrary/babylonjs.postProcess.min.js",
  41. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/loaders/babylonjs.loaders.min.js",
  42. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@4.0.3/dist/serializers/babylonjs.serializers.min.js"
  43. ],
  44. "3.3": [
  45. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/babylon.js",
  46. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/gui/babylon.gui.min.js",
  47. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/inspector/babylon.inspector.bundle.js",
  48. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/materialsLibrary/babylonjs.materials.min.js",
  49. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/proceduralTexturesLibrary/babylonjs.proceduralTextures.min.js",
  50. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/postProcessesLibrary/babylonjs.postProcess.min.js",
  51. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/loaders/babylonjs.loaders.min.js",
  52. "https://cdn.jsdelivr.net/gh/BabylonJS/Babylon.js@3.3.0/dist/serializers/babylonjs.serializers.min.js"
  53. ]
  54. };
  55. let loadScriptAsync = function(url) {
  56. return new Promise((resolve, reject) => {
  57. let script = document.createElement('script');
  58. script.src = url;
  59. script.onload = () => {
  60. resolve();
  61. }
  62. document.head.appendChild(script);
  63. });
  64. }
  65. let readStringFromStore = function(key, defaultValue) {
  66. if (localStorage.getItem(key) === null) {
  67. return defaultValue;
  68. }
  69. return localStorage.getItem(key);
  70. }
  71. let loadInSequence = async function(versions, index, resolve) {
  72. if (index >= versions.length) {
  73. resolve();
  74. return;
  75. }
  76. await loadScriptAsync(versions[index]);
  77. loadInSequence(versions, index + 1, resolve);
  78. }
  79. let checkBabylonVersionAsync= function () {
  80. let activeVersion = readStringFromStore("version", "Latest");
  81. if (activeVersion === "Latest") {
  82. return Promise.resolve();
  83. }
  84. return new Promise((resolve, reject) => {
  85. loadInSequence(Versions[activeVersion], 0, resolve);
  86. });
  87. }
  88. var storedPGObbject = BABYLON.Playground;
  89. checkBabylonVersionAsync().then(() => {
  90. if (typeof BABYLONDEVTOOLS !== 'undefined') {
  91. var hostElement = document.getElementById("host-element");
  92. storedPGObbject.Show(hostElement);
  93. return;
  94. }
  95. loadScriptAsync("/dist/babylon.playground.js").then(() => {
  96. var hostElement = document.getElementById("host-element");
  97. BABYLON.Playground.Show(hostElement);
  98. });
  99. });