0.1.8 • Published 2 years ago

nexus-widgets v0.1.8

Weekly downloads
-
License
MIT
Repository
-
Last release
2 years ago

Nexus widgets

Easy to integrate react authentication management through context. Easy to integrate header into your nexus apps

Features

  • Dead simple to integrate
  • Properly memoized authenticated attribute that can be consumed by your app

Install

$ yarn add nexus-widgets

Usage

Add AuthProvider somewhere towards the top of your tree.

// _app.tsx
import React from 'react';
import { AuthProvider} from "nexus-widgets";

function App() {

  return (
    <AuthProvider>
        <Component {...pageProps} />
    </AuthProvider>
  );
}

You can get authentication and user's photo infomation from AuthContext

// index.tsx
import React from 'react';
import { AuthContext} from "nexus-widgets";

const Home: NextPage = () => {
    const { authenticated } = React.useContext(AuthContext);
    React.useEffect(() => {

    }, [authenticated]);
    return (
        <div className="bg-white">
            <Head>
                <title>Nexus Generator</title>
                <link className='stroke-1' rel="icon" href="./nexus1.png" />
            </Head>
            <Nexus />
        </div>
  )
}
// layout.tsx
import React from 'react';
import { AuthContext} from "nexus-widgets";

const Layout = () => {
    const { userPhotoURL } = React.useContext(AuthContext);
    React.useEffect(() => {

    }, [authenticated]);
    return (
        <div className="bg-white">
            <Header
                avatar={userPhotoURL}
            />
        </div>
  )
}

Integrate setAuthenticated into your login and logout flow, here is an example of a login flow:

// Login.tsx
import React from 'react';
import { AuthContext } from "nexus-widgets";

function Login(props: RouteComponentProps) {
  const { setAuthenticated } = React.useContext(AuthContext);
  return (
    <button type="button" onClick={() => setAuthenticated(true)}>
      Login
    </button>
    <button type="button" onClick={() => setAuthenticated(false)}>
      Logout
    </button>
  );
}

Integrate setUserPhotoURL into your user photo update logic:

// Profile.tsx
import React from 'react';
import { AuthContext } from "nexus-widgets";

function Profile () {
  const { setUserPhotoURL } = React.useContext(AuthContext);
  return (
    <button type="button" onClick={() => setUserPhotoURL(url)}>
      Save user
    </button>
  );
}

Integrate header component to your app:

// Layout.tsx
import React from 'react';
import {Header, AuthContext} from "nexus-widgets"

function Layout(props: RouteComponentProps) {
  const { userPhotoURL } = React.useContext(AuthContext);
  const handleMenu =()=>{
  }
  const handleInputChange =(value)=>{
  }
  return (
    <main>
        <div className="contentArea">
            <Header
                id = {"ads"}
                avatar={userPhotoURL}
                handleMenu={handleMenu}
                handleInputChange={handleInputChange}
            />
            <div fluid>
            <div>{children}</div>
            </div>
        </div>
    </main>
  );
}
0.1.8

2 years ago

0.1.7

2 years ago

0.1.6

2 years ago

0.1.55

2 years ago

0.1.54

2 years ago

0.1.53

2 years ago

0.1.52

2 years ago

0.1.51

2 years ago

0.1.5

2 years ago

0.1.46

2 years ago

0.1.45

2 years ago

0.1.44

2 years ago

0.1.43

2 years ago

0.1.42

2 years ago

0.1.11

2 years ago

0.1.41

2 years ago

0.1.4

2 years ago

0.1.3

2 years ago

0.1.2

2 years ago

0.1.1

2 years ago