Skip to content

Commit

Permalink
Rename variables to remove references to 'global' global (facebook#12931
Browse files Browse the repository at this point in the history
)

**what is the change?:**
In a recent PR we were referencing some global variables and storing
local references to them.

To make things more natural, we co-opted the original name of the global
for our local reference. To make this work with Flow, we get the
original reference from 'window.requestAnimationFrame' and assign it to
'const requestAnimationFrame'.

Sometimes React is used in an environment where 'window' is not defined
- in that case we need to use something else, or hide the 'window'
reference somewhere.

We opted to use 'global' thinking that Babel transforms would fill that
in with the proper thing.

But for some of our fixtures we are not doing that transform on the
bundle.

**why make this change?:**
I want to unbreak this on master and then investigate more about what we
should do to fix this.

**test plan:**
run `yarn build` and open the fixtures.

**issue:**
facebook#12930
  • Loading branch information
flarnie authored May 30, 2018
1 parent ff724d3 commit 79a740c
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 10 deletions.
14 changes: 7 additions & 7 deletions packages/react-scheduler/src/ReactScheduler.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,9 +47,9 @@ import ExecutionEnvironment from 'fbjs/lib/ExecutionEnvironment';
// We capture a local reference to any global, in case it gets polyfilled after
// this module is initially evaluated.
// We want to be using a consistent implementation.
const Date = global.Date;
const setTimeout = global.setTimeout;
const clearTimeout = global.clearTimeout;
const localDate = Date;
const localSetTimeout = setTimeout;
const localClearTimeout = clearTimeout;

const hasNativePerformanceNow =
typeof performance === 'object' && typeof performance.now === 'function';
Expand All @@ -62,7 +62,7 @@ if (hasNativePerformanceNow) {
};
} else {
now = function() {
return Date.now();
return localDate.now();
};
}

Expand All @@ -86,7 +86,7 @@ if (!ExecutionEnvironment.canUseDOM) {
next: null,
prev: null,
};
const timeoutId = setTimeout(() => {
const timeoutId = localSetTimeout(() => {
callback({
timeRemaining() {
return Infinity;
Expand All @@ -101,7 +101,7 @@ if (!ExecutionEnvironment.canUseDOM) {
const callback = callbackId.scheduledCallback;
const timeoutId = timeoutIds.get(callback);
timeoutIds.delete(callbackId);
clearTimeout(timeoutId);
localClearTimeout(timeoutId);
};
} else {
let headOfPendingCallbacksLinkedList: CallbackConfigType | null = null;
Expand Down Expand Up @@ -232,7 +232,7 @@ if (!ExecutionEnvironment.canUseDOM) {
};
// Assumes that we have addEventListener in this environment. Might need
// something better for old IE.
global.addEventListener('message', idleTick, false);
window.addEventListener('message', idleTick, false);

const animationTick = function(rafTime) {
isAnimationFrameScheduled = false;
Expand Down
6 changes: 3 additions & 3 deletions packages/shared/requestAnimationFrameForReact.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,12 @@ import warning from 'fbjs/lib/warning';
// We capture a local reference to any global, in case it gets polyfilled after
// this module is initially evaluated.
// We want to be using a consistent implementation.
const requestAnimationFrame = global.requestAnimationFrame;
const localRequestAnimationFrame = requestAnimationFrame;

if (__DEV__) {
if (
ExecutionEnvironment.canUseDOM &&
typeof requestAnimationFrame !== 'function'
typeof localRequestAnimationFrame !== 'function'
) {
warning(
false,
Expand All @@ -30,4 +30,4 @@ if (__DEV__) {
}
}

export default requestAnimationFrame;
export default localRequestAnimationFrame;

0 comments on commit 79a740c

Please sign in to comment.