@upstash/claps
Add a claps button (like medium) to any page for your Next.js apps.
Nothing to maintain, it is completely serverless 💯
Check out the demo.
1. Create Database
Create a free Redis database at Upstash Console
We will use Upstash Redis to keep the data as well as
messaging (Redis pub/sub).
2. Environment Variables
Copy the .env.local.example
file to .env.local
(which will be ignored by
Git):
cp .env.local.example .env.local
UPSTASH_REDIS_REST_URL
and UPSTASH_REDIS_REST_TOKEN
can be found at the
database details page in Upstash Console.
3. Install Package
yarn add @upstash/claps
4. Import CSS
import "@upstash/claps/style.css";
export default function MyApp({ Component, pageProps }) {
return <Component {...pageProps} />;
}
4. Import Components
import Claps from "@upstash/claps";
export default function Example() {
return (
<div>
<Claps fixed="left">
</div>
)
}
The options can be passed as React props
key | type | default |
---|
key? | string | |
fixed? | "left", "center", "right" | |
replyUrl? | string | |
replyCount? | string | |
apiPath? | string | /api/claps |
iconClap? | null, React.ReactElement | |
iconReply? | null, React.ReactElement | |
shareButton? | boolean | true |
Url of the page is being used as the key/identity to keep the claps count. You
can override this giving the key
attribute.
5. Create API
import createClapsAPI from "@upstash/claps/api";
const ClapsAPI = createClapsAPI({
});
export default ClapsAPI;
Support
Use Upstash Discord channel to get support.