How to Integrate Grammarly Text Editor SDK into React App

How to Integrate Grammarly Text Editor SDK into React App

Written by Ayodele Samuel Adebayo on Oct 3rd, 2022 Views Report Post

Grammarly is a cloud-based typing assistant that helps writers to develop content with accurate spelling, punctuation, and grammar within a text editor.

Grammarlys browser extensions improve grammar, clarity, and more as you write on your favorite sites.

Check out my favorite Grammarly for business Ads on YouTube.

https://youtu.be/Nc444sDAKmM

What is Grammarly for Browser?

Grammarly is popularly known for fixing grammatical errors within a website's text editor through its browser extensions and it's compatible with popular websites such as Hashnode, Twitter, LinkedIn, Notion, Gmail and other websites that support third-party plugins like Grammarly browser extension.

Grammarly Check your grammar, spelling, and punctuation

You can install the Grammarly browser extension for your browser here.

What is Grammarly for Developers?

Grammarly for developers is a newly created feature on Grammarly that enables developers to develop an in-built real-time typing assistance into their web app text editors using Grammarly's SDK.

Deliver high-quality writing assistance with Grammarly's SDK

With Grammarly SDK, you can deliver real-time writing suggestions and all the Grammarly features out of the box for your end users (they don't need to download the Grammarly browser extension).

Note: Some suggestions may only be available to paid Grammarly users who connect their accounts.

The Grammarly SDK is available for clients like JavaScript, React, Vue, and Electron (for desktop clients). We'll explore the Grammarly React SDK in this article.

Step 1 - Creating a New Grammarly for Developer App

Before using the Grammarly SDK, you must first create a Grammarly app and generate a unique client ID for your project. These credentials will be used for accessing Grammarly's services from either web or desktop applications.

  • Visit www.grammarly.com/signin to log in with your existing Grammarly account or create a new account here:

    signing up on Grammarly; In addition to Grammarly Text Editor SDK access, youll get a free Grammarly account.

  • After the authentication, navigate to the Grammarly My apps dashboard, which looks something like this:

    steps to creating a Grammarly SDK app

  • Next, click on the New app button:

    steps to creating a Grammarly SDK app

  • Give your new app a name and click on the Create button:

    steps to creating a Grammarly SDK app

  • Next, you'll be redirected to your app dashboard where you can access your app client ID: steps to creating Grammarly for developer app

We'll use the client ID in our React application.

Step 2 - Creating a New React App

[Skip](#Step 3 - Installing Grammarly React SDK) this step if you want to set up Grammarly for an existing React app.

  • Run the create-react-app command below to create a new React app:

    yarn create react-app grammarly-writing-assistance  
    
    
  • After installation, navigate into the newly created directory with the command below:

    cd grammarly-writing-assistance  
    
    
  • Finally, run the command below to start your server:

    yarn run start  
    
    

    starting a react server

Step 3 - Installing Grammarly React SDK

Run the command below to install the Grammarly React Text Editor SDK in your app:

  • Using yarn package manager:

    yarn add @grammarly/editor-sdk-react  
    
    
  • Using npm package manager:

    npm install @grammarly/editor-sdk-react  
    
    

Step 4 - Creating a Text Editor

After installing the @grammarly/editor-sdk-react library:

  • Open your project folder in your favorite code editor (I love VScode 🥳).
  • Next, create a new component folder in the src folder.
  • Create a new InputTextEditor.jsx with the following line of code:
<span class="hljs-keyword">import</span> React <span class="hljs-keyword">from</span> <span class="hljs-string">"react"</span>;

<span class="hljs-keyword">export</span> <span class="hljs-keyword">const</span> InputTextEditor = <span class="hljs-function">() =></span> {  
  <span class="hljs-keyword">return</span> (  
    <span class="xml"><span class="hljs-tag"><<span class="hljs-name">React.Fragment</span>></span>  
      <span class="hljs-tag"><<span class="hljs-name">input</span> <span class="hljs-attr">type</span>=<span class="hljs-string">'text'</span> <span class="hljs-attr">placeholder</span>=<span class="hljs-string">"What's on your mind today? 😃"</span> /></span>  
    <span class="hljs-tag"></<span class="hljs-name">React.Fragment</span>></span></span>  
  );  
};

  • Next, render the InputTextEditor in the App.js file:
<span class="hljs-keyword">import</span> <span class="hljs-string">"./App.css"</span>;  
<span class="hljs-keyword">import</span> { InputTextEditor } <span class="hljs-keyword">from</span> <span class="hljs-string">"./components/InputTextEditor"</span>;

<span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">App</span>(<span class="hljs-params"></span>) </span>{  
  <span class="hljs-keyword">return</span> (  
    <span class="xml"><span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">className</span>=<span class="hljs-string">'App'</span>></span>  
      <span class="hljs-tag"><<span class="hljs-name">header</span> <span class="hljs-attr">className</span>=<span class="hljs-string">'App-header'</span>></span>  
        <span class="hljs-tag"><<span class="hljs-name">InputTextEditor</span> /></span>  
      <span class="hljs-tag"></<span class="hljs-name">header</span>></span>  
    <span class="hljs-tag"></<span class="hljs-name">div</span>></span></span>  
  );  
}

<span class="hljs-keyword">export</span> <span class="hljs-keyword">default</span> App;

  • Finally, add the following CSS to your App.css file:
<span class="hljs-selector-tag">input</span>{  
  <span class="hljs-attribute">padding</span>: <span class="hljs-number">10px</span>;  
  <span class="hljs-attribute">width</span>: <span class="hljs-number">50%</span>;  
  <span class="hljs-attribute">font-size</span>: <span class="hljs-number">1.5rem</span>;  
}

Our text editor app should now look something like this:

Grammarly text editor

If you prefer a textarea tag, replace the input tag with the following code:

<span class="hljs-keyword">import</span> React <span class="hljs-keyword">from</span> <span class="hljs-string">"react"</span>;  
<span class="hljs-keyword">import</span> { GrammarlyEditorPlugin } <span class="hljs-keyword">from</span> <span class="hljs-string">"@grammarly/editor-sdk-react"</span>;

<span class="hljs-keyword">export</span> <span class="hljs-keyword">const</span> InputTextEditor = <span class="hljs-function">() =></span> {  
  <span class="hljs-keyword">return</span> (  
    <span class="xml"><span class="hljs-tag"><<span class="hljs-name">React.Fragment</span>></span>  
      <span class="hljs-tag"><<span class="hljs-name">GrammarlyEditorPlugin</span>  
        <span class="hljs-attr">clientId</span>=<span class="hljs-string">{process.env.REACT_APP_GRAMMARLY_CLIENT_ID}</span>  
        <span class="hljs-attr">style</span>=<span class="hljs-string">{{</span> <span class="hljs-attr">width:</span> "<span class="hljs-attr">100</span>%" }}  
      ></span>  
        <span class="hljs-tag"><<span class="hljs-name">textarea</span> <span class="hljs-attr">placeholder</span>=<span class="hljs-string">"What's on your mind today? 😃"</span> /></span>  
      <span class="hljs-tag"></<span class="hljs-name">GrammarlyEditorPlugin</span>></span>  
    <span class="hljs-tag"></<span class="hljs-name">React.Fragment</span>></span></span>  
  );  
};

And add the following CSS code to your App.css file:

<span class="hljs-selector-tag">textarea</span>{  
  <span class="hljs-attribute">height</span>: <span class="hljs-number">250px</span>;  
  <span class="hljs-attribute">width</span>: <span class="hljs-number">50%</span>;  
  <span class="hljs-attribute">font-size</span>: <span class="hljs-number">1rem</span>;  
}

Our text editor app should now look something like this:

Grammarly text editor

Step 5 - Integrating Grammarly into Text Editor

  • Import the GrammarlyEditorPlugin component in the editor component and wrap it around the input tag, like this:

    <span class="hljs-keyword">import</span> React <span class="hljs-keyword">from</span> <span class="hljs-string">"react"</span>;  
    <span class="hljs-keyword">import</span> { GrammarlyEditorPlugin } <span class="hljs-keyword">from</span> <span class="hljs-string">"@grammarly/editor-sdk-react"</span>;  
    
    <span class="hljs-keyword">export</span> <span class="hljs-keyword">const</span> InputTextEditor = <span class="hljs-function">() =></span> {  
      <span class="hljs-keyword">return</span> (  
        <span class="xml"><span class="hljs-tag"><<span class="hljs-name">React.Fragment</span>></span>  
          <span class="hljs-tag"><<span class="hljs-name">GrammarlyEditorPlugin</span>  
            <span class="hljs-attr">clientId</span>=<span class="hljs-string">{process.env.REACT_APP_GRAMMARLY_CLIENT_ID}</span>  
            <span class="hljs-attr">style</span>=<span class="hljs-string">{{</span> <span class="hljs-attr">width:</span> "<span class="hljs-attr">100</span>%" }}  
          ></span>  
            <span class="hljs-tag"><<span class="hljs-name">input</span> <span class="hljs-attr">type</span>=<span class="hljs-string">'text'</span> <span class="hljs-attr">placeholder</span>=<span class="hljs-string">"What's on your mind today? 😃"</span> /></span>  
          <span class="hljs-tag"></<span class="hljs-name">GrammarlyEditorPlugin</span>></span>  
        <span class="hljs-tag"></<span class="hljs-name">React.Fragment</span>></span></span>  
      );  
    };  
    
    
  • Create a new .env file at the root of your project and add your Grammarly client ID, as shown below:

    REACT_APP_GRAMMARLY_CLIENT_ID=your-client-id  
    
    

Note: Restart your React app server after updating your .env file.

To know that Grammarly is successfully integrated into your project, you'll see the Grammarly button displayed in the lower-right corner of your text editor page.

Grammarly button will be displayed in the lower-right corner of the text editor when successful

If you don't see the Grammarly button on your browser, check your console for any message like this:

image.png

To resolve this, ensure to disable or uninstall the Grammarly browser extension and focus on the editor.

Step 6 - Testing the Grammarly Writing Assistance

In this step, we're going to test our Grammar writing assistance by writing incorrect words and sentences.

Test 1 - Inaccurate name capitalization

my name is samuel

grammarly correcting name capitalization.gif

Test passed

Test 2 - Incorrect spellings

grammarly is a cloud based typing asistant that helps writer to develops content with accurate spellng, punctuations and grammar within a text editors.

grammarly correcting incorrect spellings in a text area

Test passed

Test 3 - Sentence Clarity

It goes without saying that sometimes you can actually improve a sentence by completely eliminating words that are basically unnecessary.

grammarly correcting sentence clarity

Test passed

Frequently Asked Questions on Grammarly

Q1: Which platform is not supported by Grammarly?
Ans: Dropbox doesn't support Grammarly or any third-party plugins.

Q2: How can I add the Grammarly tune feature to my editor?
Ans: You can go beyond suggestion by upgrading your account on Grammarly. See the pricing list here.

**Q3: How do I enable paid features for my end users?**Ans: To enable premium features for your users who have a premium account with Grammarly. Navigate to your dashboard and turn ON the Connected accounts option:

how to enable connected accounts on Grammarly

Q4: Will I be charged for my users' Connected accounts?
Ans: No, only accounts with premium plans will be able to use the Grammarly paid features on your app.

Wrapping Up 🏽

Grammarly is a comprehensive writing tool that helps you write clear and error-free content, and the Grammarly Text Editor SDK allows you to offer all Grammarly features out of the box on your website.

In this article, we covered how to create a Grammarly-for-developer account and how to integrate the Grammarly Text Editor SDK into a React application.

Comments (0)