Skip to content

a react hook with component managing access easily.

Notifications You must be signed in to change notification settings

catynaimiao/useAccess

Repository files navigation

🪝useAccess

a react hook with component managing access easily.

you can quickly combine it in your Nextjs or other projects.

📝 basic usage

import useSubcribe and AccessProvider

// App.js
// example for use useSubcribe ,recommend using useSWR.
const fetcher = () =>
  fetch("http://localhost:3000/access").then((response) => response.json());
const access = useSubcribe(fetcher);

return (
  <AccessProvider value={access}>
    // provide the access here.
    <Home />
  </AccessProvider>
);

using useAccess to get the access.

// Home.js
const access = useAccess(); // get access using hook.

return (
  <div>
    <Access accessiable={access.canRead}>
      {"show hello world if the accessiable is true."}
      <h1>Hello world! I have access.</h1>
    </Access>
    <Access accessiable={false} failcallback={<h1>I don't have Access</h1>}>
      {"if accessiable is falthy then render failcallback."}
      <h1>Hello world! I have access.</h1>
    </Access>
  </div>
);

examples

install dependencies.

yarn install

use terminal run scripts following in different window.

yarn example-server
yarn example-web-useSubcribeExample

then open http://localhost:1234 in broswer.

backend uses the json-server you can edit the ./examples/server/db.json and rerun the yarn example-server.

recommend access standard

{
  "access": {
    "canReadPost": true,
    "canUpdatePost": true,
    "canDeletePost": true
  }
}

you can implement a selector in more complex project. and just a callbackFunction and parse the access got from fetcher. (ps: don't worry mutate the param access)

const selector = (access) => access.posts;
const posts_access = useAccess(selector);

and you can define the access response structure like this:

{
  "access": {
    "posts": {
      "canReadPost": true,
      "canUpdatePost": true,
      "canDeletePost": true
    },
    "otherResource": {
      "canRead": false
    }
  },
  "errMsg": null
}

🚧 plan in the future

  • 🛠 feat : custom global access config.
  • 🛠 feat : automated access template generate.
  • 📚 docs : examples with nextauth.
  • 📚 docs : combine with nextauth.

About

a react hook with component managing access easily.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published