-
-
Notifications
You must be signed in to change notification settings - Fork 3.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Defer initialization until end of aframe script or manual ready signal (
#5481) Co-authored-by: Noeri Huisman <mrxz@users.noreply.github.com> Co-authored-by: Chris Chua <chris.sirhc@gmail.com>
- Loading branch information
1 parent
af4523e
commit 4a89bb6
Showing
11 changed files
with
166 additions
and
58 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/* global CustomEvent */ | ||
|
||
/** | ||
* Flag indicating if A-Frame can initialize the scene or should wait. | ||
*/ | ||
module.exports.canInitializeElements = false; | ||
|
||
/** | ||
* Waits for the document to be ready. | ||
*/ | ||
function waitForDocumentReadyState () { | ||
if (document.readyState === 'complete') { | ||
emitReady(); | ||
return; | ||
} | ||
|
||
document.addEventListener('readystatechange', function onReadyStateChange () { | ||
if (document.readyState !== 'complete') { return; } | ||
document.removeEventListener('readystatechange', onReadyStateChange); | ||
emitReady(); | ||
}); | ||
} | ||
module.exports.waitForDocumentReadyState = waitForDocumentReadyState; | ||
|
||
/** | ||
* Signals A-Frame that everything is ready to initialize. | ||
*/ | ||
function emitReady () { | ||
if (module.exports.canInitializeElements) { return; } | ||
module.exports.canInitializeElements = true; | ||
setTimeout(function () { | ||
document.dispatchEvent(new CustomEvent('aframeready')); | ||
}); | ||
} | ||
module.exports.emitReady = emitReady; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
/* global AFRAME, assert, suite, test, setup */ | ||
var readyState = require('core/readyState'); | ||
|
||
suite('readyState', function () { | ||
setup(function (done) { | ||
// Test setup initializes AFRAME when document is already ready. | ||
// This timeout ensures the readyState is reset before running the tests here. | ||
setTimeout(function () { | ||
readyState.canInitializeElements = false; | ||
done(); | ||
}); | ||
}); | ||
|
||
suite('waitForDocumentReadyState', function () { | ||
test('emits aframeready when document is ready', function (done) { | ||
var listenerSpy = this.sinon.spy(); | ||
document.addEventListener('aframeready', listenerSpy); | ||
|
||
assert.equal(document.readyState, 'complete'); | ||
readyState.waitForDocumentReadyState(); | ||
|
||
setTimeout(function () { | ||
assert.ok(listenerSpy.calledOnce); | ||
done(); | ||
}); | ||
}); | ||
}); | ||
|
||
suite('emitReady', function () { | ||
test('emits aframeready', function (done) { | ||
var listenerSpy = this.sinon.spy(); | ||
document.addEventListener('aframeready', listenerSpy); | ||
|
||
assert.ok(listenerSpy.notCalled); | ||
readyState.emitReady(); | ||
|
||
setTimeout(function () { | ||
assert.ok(listenerSpy.calledOnce); | ||
assert.ok(readyState.canInitializeElements); | ||
done(); | ||
}); | ||
}); | ||
|
||
test('emits aframeready event only once', function (done) { | ||
var listenerSpy = this.sinon.spy(); | ||
document.addEventListener('aframeready', listenerSpy); | ||
|
||
assert.ok(listenerSpy.notCalled); | ||
// Calling emitReady multiple times should result in only one event being emitted. | ||
readyState.emitReady(); | ||
readyState.emitReady(); | ||
|
||
setTimeout(function () { | ||
assert.ok(listenerSpy.calledOnce); | ||
assert.ok(readyState.canInitializeElements); | ||
|
||
// Calling again after the event fired should not emit. | ||
readyState.emitReady(); | ||
setTimeout(function () { | ||
// Assert total count is still only once. | ||
assert.ok(listenerSpy.calledOnce); | ||
assert.ok(readyState.canInitializeElements); | ||
done(); | ||
}); | ||
}); | ||
}); | ||
}); | ||
}); |