-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cannot enable Universal Rendering in projects using activity-detector #10
Comments
What about using dynamic A different approach could be to Access lazily to the document insterad of at the first load. |
That's available in some specific environments only. Adding a simple guard for the availability of |
You could just add this to your
Webpack and Browserify both respect this as far as I know. |
I've had this same issue. We've forked the code (since it's just one file) and moved the |
I'm trying to use it with a Sapper project and since Sapper is the SSR belt on top of Svelte I have the exact same issue with SSR since there is no I've just tried @louh 's suggestion, moving the check for document inside var activityDetector = function activityDetector () {
// moved below snippet inside activityDetector so it works with SSR frameworks such as Sapper
if (typeof document.hidden !== 'undefined') {
hidden = 'hidden';
visibilityChangeEvent = 'visibilitychange';
} else {
var prefixes = ['webkit', 'moz', 'ms'];
for (var i = 0; i < prefixes.length; i++) {
var prefix = prefixes[i];
if (typeof document[prefix + 'Hidden'] !== 'undefined') {
hidden = prefix + 'Hidden';
visibilityChangeEvent = prefix + 'visibilitychange';
break;
}
}
}
var _listeners;
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref$activityEvents = _ref.activityEvents,
activityEvents = _ref$activityEvents === undefined ? DEFAULT_ACTIVITY_EVENTS : _ref$activityEvents,
_ref$inactivityEvents = _ref.inactivityEvents,
inactivityEvents = _ref$inactivityEvents === undefined ? DEFAULT_INACTIVITY_EVENTS : _ref$inactivityEvents,
_ref$ignoredEventsWhe = _ref.ignoredEventsWhenIdle,
ignoredEventsWhenIdle = _ref$ignoredEventsWhe === undefined ? DEFAULT_IGNORED_EVENTS_WHEN_IDLE : _ref$ignoredEventsWhe,
_ref$timeToIdle = _ref.timeToIdle,
timeToIdle = _ref$timeToIdle === undefined ? 30000 : _ref$timeToIdle,
_ref$initialState = _ref.initialState,
initialState = _ref$initialState === undefined ? DEFAULT_INITIAL_STATE : _ref$initialState,
_ref$autoInit = _ref.autoInit,
autoInit = _ref$autoInit === undefined ? true : _ref$autoInit;
... It all works fine on Sapper with SSR now too. Can we please make this change and make it offical so all SSR frameworks can us activity-detector as well! 🥳 |
@evdama That's exactly what we did. And we have our project running in production quite successfully this way, so I think it's a worthy change to make. Thanks for separately trying out and confirming that this works. I'm going to create a PR for this to nudge this along. |
Currently, this module fails in SSR because it reads from the `document` global variable when it is evaluated at compile time. This fix moves reading the `document` variable from the top level of the module, into the body of the `activityDetector` function, whose contents are not evaluated when bundling. This allows the module to work as-is in apps that do SSR. See this issue: tuenti#10
@atabel Please take a look, thank you! |
activity-detector is only meaningful when running code in a browser, so for a project that uses Universal Rendering (Server Side Rendering) it should not be part of the server side code path.
The problem is that activity-detector tries to unsafely access the
document
object already duringimport
, which breaks the app before any conditional code paths can be selected. And it is currently not possible to conditionally import modules.The text was updated successfully, but these errors were encountered: