A package for integrating Disqus services into React applications.
Installation
Using npm:
$ npm install --save disqus-react
Using yarn:
$ yarn add disqus-react
Usage
DiscussionEmbed
This is the component that will load the main Disqus comments section.
import { DiscussionEmbed } from 'disqus-react';
<DiscussionEmbed
shortname='example'
config={
{
url: this.props.article.url,
identifier: this.props.article.id,
title: this.props.article.title,
language: 'zh_TW' //e.g. for Traditional Chinese (Taiwan)
}
}
/>
This component is limited to one instance in the DOM at a time and will handle updates to both the config
and shortname
props and reload appropriately with the new discussion thread.
language
configuration
This configuration overrides will load the Disqus embed in different languages on a per-page basis.
Language dode can be found on: https://www.transifex.com/explore/languages/ give that the language is available on https://www.transifex.com/disqus/disqus/
This component will display the comment count for the Disqus thread associated with the provided config.
import { CommentCount } from 'disqus-react';
<Disqus.CommentCount
shortname='example'
config={
{
url: this.props.article.url,
identifier: this.props.article.id,
title: this.props.article.title,
}
}
>
{/* Placeholder Text */}
Comments
</Disqus.CommentCount>
Multiple instances of this component can be included on the same page with different config
variables (e.g. an article list showing the comment count for each).
However, all threads on the site must be under the same primary site shortname
. If the component receives a new shortname
, all instances will be reset with counts for threads matching the updated site.
This component can be used to embed a Disqus comment into your page.
import { CommentEmbed } from 'disqus-react';
<CommentEmbed
commentId={this.props.article.featuredCommentId}
showMedia={true}
showParentComment={true}
width={420}
height={320}
/>
Multiple instances of this component may be include on the same page with different commentId
variables and does not require that the embedded comment be under the same primary site shortname
.
Contributing
If you'd like to contribute to this package feel free to submit a bug report, feature request, or pull request. Though we would ask that you first read through the contributing guidelines.