Skip to content
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

ReferenceError: document is not defined at createTag... #101

Open
Beruguru opened this issue Nov 1, 2023 · 21 comments
Open

ReferenceError: document is not defined at createTag... #101

Beruguru opened this issue Nov 1, 2023 · 21 comments

Comments

@Beruguru
Copy link

Beruguru commented Nov 1, 2023

Hello everyone,

I had some issues with ReferenceError (with SSR).
And yes I know, it could be solved by dynamic import, lazy or maybe some other ways.

But the situation is like below:

  • There is a main(index) page with Lottie (lottie-react)
  • I've even use useEffect with isMount state to render the Lottie after the mount

case1.

  • No errors and works fine in Node 18 (v.18.18.0)

case2.

  • ReferenceError: document is not defined at createTag... occurs in higher version of Node (20, 21)

So, we (I and my co-worker) decided to fix Node version to 18 and it works fine.

But we are just curious about it.
Try to figure it out but all we can find is that the node version effects build in somehow.

If anyone knows what has been changed between 18 and higher, it would be nice to know of it.

Thank you so much.

@xgg94
Copy link

xgg94 commented Nov 2, 2023

Got the same error

@dharmatriyasa
Copy link

Got the same error, but everything works fine

@bytemtek
Copy link

bytemtek commented Nov 9, 2023

Same error.

@ZhariffAdam
Copy link

use nvm 18.18.2 for temporary

@xereda
Copy link

xereda commented Dec 1, 2023

same error with node 21

@hewelt
Copy link

hewelt commented Dec 5, 2023

Hey folks, this error happens because lottie-web, dependency of lottie-react depends on the condition of typeof navigator !== "undefined" to determine if it runs in browser or server environment:

if (typeof navigator !== "undefined") {
  // client-side code
  } else {
  // server-side code
}

This is not valid anymore though, because Node v21 introduces a new navigator API, previously present only in client-side code. So document is now reached when being run in Node. One solution would be for lottie-web to just change that condition to one that clearly distinguishes between client and server.

@Beruguru
Copy link
Author

Beruguru commented Dec 5, 2023

Hey folks, this error happens because lottie-web, dependency of lottie-react depends on the condition of typeof navigator !== "undefined" to determine if it runs in browser or server environment:

if (typeof navigator !== "undefined") {
  // client-side code
  } else {
  // server-side code
}

This is not valid anymore though, because Node v21 introduces a new navigator API, previously present only in client-side code. So document is now reached when being run in Node. One solution would be for lottie-web to just change that condition to one that clearly distinguishes between client and server.

Thank you so much!
I was so wondering why this happenend and thanks for the sharing.^_^

@Beruguru Beruguru closed this as completed Dec 5, 2023
@xereda
Copy link

xereda commented Dec 8, 2023

@ZhariffAdam

Why was this issue closed? Was solved?
Is there a plan for support for node 21?

Thank you for now

@AlonMiz
Copy link

AlonMiz commented Jan 10, 2024

this issue should remain open. not fixed for node >= 20

@andregoncalvesdev
Copy link

this issue should remain open. not fixed for node >= 20

+1

@Beruguru
Copy link
Author

Oh I am sorry.
I didn't know it has to be open until the fix.
I will reopen it~

@Beruguru Beruguru reopened this Jan 11, 2024
@AlonMiz
Copy link

AlonMiz commented Jan 11, 2024

thanks @Beruguru 🙏
i worked on a workaround with some additional benefits
Lazyloading the lottie module as loading lazily the animation json

  1. less bundle from package - which is pretty large (81.9 kB MINIFIED + GZIPPED) - https://bundlephobia.com/package/[email protected]
  2. less bundle for loading the json - will be load lazily as well - as they can get quite large as well

EDIT: I had a chance to write a small article

https://medium.com/@alonmiz1234/lazy-load-lottie-animation-in-react-e58e67e2aa74

this example uses Skeleton from mantine but it can be replace with a simple loading animation you already have

LazyLottie (Optimized for SSR)

import { Skeleton } from '@mantine/core';
import { useQuery } from '@tanstack/react-query';
import { type LottieComponentProps } from 'lottie-react';
import { Suspense, lazy, useEffect, useRef, useState } from 'react';

const LazyLottieComponent = lazy(() => import('lottie-react'));

interface LottieProps<T extends Record<string, unknown>> {
  getJson: () => Promise<T>;
  id: string;
}

export function LazyLottie<T extends Record<string, unknown>>({
  getJson,
  id,
  ref,
  ...props
}: LottieProps<T> & Omit<LottieComponentProps, 'animationData'>) {
  const { data } = useQuery({
    queryKey: [id],
    queryFn: getJson,
    enabled: typeof window !== 'undefined',
  });

  if (!data) return <Skeleton height={props.height} width={props.width} />;

  return (
    <Suspense fallback={<Skeleton height={props.height} width={props.width} />}>
      <LazyLottieComponent animationData={data} {...props} />
    </Suspense>
  );
}

Usage

export const EmptyState: React.FC = () => {
  return (
    <LazyLottie
      getJson={() => import('../../../assets/lottie/empty-box.json')}
      loop
      id="empty-box"
      width={120}
      height={120}
    />
  );
};

@dragoshuniq
Copy link

dragoshuniq commented Jan 16, 2024

Next.js. Lottie-web uses the window object, which is not available during SSR. To fix this use the following code:
Ref here

import dynamic from 'next/dynamic';
const Lottie = dynamic(() => import('react-lottie'), { ssr: false });

alban-lautie added a commit to alban-lautie/marvel-hereos that referenced this issue May 4, 2024
@alan-nousot
Copy link

Running into this issue consistently from using lottie-react in a component library that doesn't use next with nodejs 20.12.2. Lazy importing react-lottie or the component itself doesn't work either.

@sxxov
Copy link

sxxov commented May 20, 2024

@alan-nousot If you're importing a named export that uses lottie-react, you can try the following:

const Component = dynamic(
	async () =>
		import('library').then(({ Component }) => ({
			default: Component, // note the alias to `default`!
		})),
	{ ssr: false },
);

plasmicops pushed a commit to plasmicapp/plasmic that referenced this issue Jun 27, 2024
Related to this github issue: Gamote/lottie-react#101

Issue: https://linear.app/plasmic/issue/PLA-10954/lottie-hostless-causing-issue
Change-Id: Ifc5ebd7527a20a86ab05d40f0cb8391daaad86c9
GitOrigin-RevId: 5792ca5bafdb2f4a112c78cb0de116f3aac50968
@nixjs
Copy link

nixjs commented Jun 28, 2024

Use node 18.17.0 to resolve

@csori99
Copy link

csori99 commented Sep 5, 2024

When is Lottie team planning to fix it? have been months

@beardsleym
Copy link

I was using Node v22, using v20 sorted it out.

@MartinGerritsen
Copy link

Same issue here, had to downgrade node

@yfrommelt
Copy link

You can add NODE_OPTIONS="--no-experimental-global-navigator" before you dev /build script to disable the Navigator API in Node v21

@Badestrand
Copy link

Seems to be fixed with latest lottie-web 5.13 which is merged but not released to npm yet, see airbnb/lottie-web#3136

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests