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

Navigator error #29

Closed
aaronchan32 opened this issue Aug 10, 2020 · 1 comment
Closed

Navigator error #29

aaronchan32 opened this issue Aug 10, 2020 · 1 comment
Labels
question Further information is requested

Comments

@aaronchan32
Copy link

I added the AlanButton to my app:

import alanBtn from "@alan-ai/alan-sdk-web";
alanBtn({
 key: "myKey",
 rootEl: document.getElementById("alan-btn")
});
 
function Layout({ children }) {return (
   <>
     <Header />
 
     <main>
       <Banner />
 
       {children}
       <div id="alan-btn"></div>
     </main>
 
     <Footer />
   </>
 );
}

I get this error when I build it:

ReferenceError: navigator is not defined
    at undefined.window.alanAudio (/Users/aaron/Work/ssrtest/node_modules/@alan-ai/alan-sdk-web/index.js:13:5)
    at /Users/aaron/Work/ssrtest/node_modules/@alan-ai/alan-sdk-web/index.js:271:3
    at /Users/aaron/Work/ssrtest/node_modules/@alan-ai/alan-sdk-web/index.js:5:22
    at Object.<anonymous> (/Users/aaron/Work/ssrtest/node_modules/@alan-ai/alan-sdk-web/index.js:9:2)
    at Module._compile (internal/modules/cjs/loader.js:776:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:787:10)
    at Module.load (internal/modules/cjs/loader.js:653:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    at Function.Module._load (internal/modules/cjs/loader.js:585:3)
    at Module.require (internal/modules/cjs/loader.js:690:17)
@annmirosh
Copy link
Contributor

Hi, @aaronchan32 ,

it looks like you're trying to use the Alan Button in the server-side rendered app. If it's a case, here is how you can use it:

import React, { useEffect } from 'react';

function Layout({ children }) {
  useEffect(() => {
    const alanBtn = require('@alan-ai/alan-sdk-web');
    alanBtn({
      key: "myKey",
      rootEl: document.getElementById("alan-btn")
    });
  }, []);

  return (
    <>
      <Header />
      <main>
        <Banner />
        {children}
        <div id="alan-btn"></div>
      </main>
      <Footer />
    </>
  );
}

@andreyryabov andreyryabov added help wanted Extra attention is needed question Further information is requested and removed help wanted Extra attention is needed labels Aug 11, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

3 participants