Canny.io integration for react
npm install react-canny
ℹ️ Widget component name changed from CannyWidget to CannyFeedback.
import {
CannyProvider,
CannyFeedback
} from "react-canny";
const APP_ID = "/* Your app id */";
const BOARD_TOKEN = "/* Tour token board */";
const SSO_TOKEN = "/* Your sso token */";
const App = () => {
return (
<CannyProvider appId={APP_ID}>
<CannyFeedback
basePath="/feedback"
boardToken={BOARD_TOKEN}
ssoToken={SSO_TOKEN} />
</CannyProvider>
);
};
import {
CannyProvider,
CannyChangelog
} from "react-canny";
const APP_ID = "/* Your app id */";
const LABEL_IDS = [/* Your label ids */];
const App = () => {
return (
<CannyProvider appId={APP_ID}>
<CannyChangelog
type="button"
className="change-log-button"
align="top"
position="left"
labelIDs={LABEL_IDS}>
Change Log
</CannyChangelog>
</CannyProvider>
);
};
Also, you can customize your change log button:
const APP_ID = "/* Your app id */";
const CustomButton = (props) => {
return (
<button {...props}
type="button"
className="my-custom-button" />
);
};
const App = () => {
return (
<CannyProvider appId={APP_ID}>
<CannyChangelog
component={CustomButton}>
Change Log
</CannyChangelog>
</CannyProvider>
);
};
Canny Identify is built-into the CannyProvider, and specifying the user details will trigger user identification.
import { CannyProvider } from "react-canny";
const APP_ID = "/* Your app id */";
const USER = {
id: "/* User id */",
name: "/* User name */",
email: "/* User email */"
};
const App = () => {
const onIdentify = () => {
/* An optional callback */
};
return (
<CannyProvider
appId={APP_ID}
user={USER}
onIdentify={onIdentify} />
);
};
If Canny Identify isn't working and you need to generate an authenticated link yourself, use authenticateCannyLink
.
import { CannyProvider, useCannyContext } from "react-canny";
const APP_ID = "/* Your app id */";
const USER = {
id: "/* User id */",
name: "/* User name */",
email: "/* User email */"
};
const CANNY_URL = 'https://my-subdomain.canny.io';
const App = () => {
return (
<CannyProvider appId={APP_ID} user={USER}>
<CannyLink href={CANNY_URL}>
Leave feedback
</CannyLink>
</CannyProvider>
);
};
const CannyLink = ({ children, href }) => {
const { canny, isLoaded } = useCannyContext();
if(!isLoaded) {
return null;
}
return (
<a href={canny.authenticateCannyLink(href)}>{children}</a>
);
};