Skip to content

react-linkify-it 1.0.0

Install from the command line:
Learn more about npm packages
$ npm install @anantoghosh/react-linkify-it@1.0.0
Install via package.json:
"@anantoghosh/react-linkify-it": "1.0.0"

About this version

react-linkify-it πŸ”—

Npm version Node.js CI Min zipped size Min zipped size

A tiny universal linking solution that turns any pattern in your text clickable (aka linkify).

react-linkify-it comes with a set of prebuilt components for specific linking needs and a generic component to wrap any pattern with a component.

Prebuilt components for linking:

  • URLs
  • Jira Tickets
  • Twitter usernames
  • Emails

You can also use the generic component which lets you support your own use case as desired:

  • Link GitHub Issues
  • Link tags to any social media
  • Link email addresses
  • Link phone numbers
  • Link any pattern you want!
  • Wrap any pattern with a component!

Features

  • πŸ“¦ Tiny - Less than 800 bytes gzipped after tree shaking.
  • πŸ“ Customizable - Adjust to your specific case as required.
  • πŸ’§ Generic - Not just links, wrap any pattern with any component.
  • 🏎 Fast - Single pass processing.
  • 🦺 Safe - Sanitized urls to prevent any XSS attacks.
  • 🌐 i18n - Works with urls that contain international characters.
  • βš” Tested - Thoroughly.
  • πŸ•Έ React support - Works with react v16.2+

Notes

  • react-linkify-it provides a modern bundle for actively maintained browsers and a larger legacy bundle for older browsers.
    Read about how to utilize them.

Demo

https://codesandbox.io/s/objective-shannon-c5n82g?file=/src/App.js

Installation

npm i react-linkify-it

Usage - Prebuilt Components

Every prebuilt component also optionally accepts a className to attach to the link wrapper

1. Urls

import { LinkItUrl } from 'react-linkify-it';

const App = () => (
  <div className="App">
    <LinkItUrl>
      <p>"add some link https://www.google.com here"</p>
    </LinkItUrl>
  </div>
);

2. Jira Tickets

import { LinkItJira } from 'react-linkify-it';

const App = () => (
  <div className="App">
    <LinkItJira domain="https://projectid.atlassian.net">
      hello AMM-123 ticket
    </LinkItJira>
  </div>
);

3. Twitter handles

import { LinkItTwitter } from 'react-linkify-it';

const App = () => (
  <div className="App">
    <LinkItTwitter>
      hello @anantoghosh twitter
    </LinkItTwitter>
  </div>
);

4. Emails

import { LinkItEmail } from 'react-linkify-it';

const App = () => (
  <div className="App">
    <LinkItEmail>
      hello [email protected] email
    </LinkItEmail>
  </div>
);

Usage - Generic Component

import { LinkIt } from 'react-linkify-it';

const regexToMatch = /@([\w_]+)/;

const App = () => (
  <div className="App">
    <LinkIt
      {/* Component to wrap each match with */}
      component={(match, key) => <a href={match} key={key}>{match}</a>}
      regex={regexToMatch}
    >
      www.google.com<div>hi @anantoghosh</div>
    </LinkIt>
  </div>
);
  • match - regex match text
  • key - unique key for the match

Usage - Generic Function

import { linkIt, UrlComponent } from 'react-linkify-it';

const regexToMatch = /@([\w_]+)/;

const App = () => {

  const output = linkIt(
    // Text to be linkified
    text,
    // Component to wrap each match with, can be any React component
    (match, key) => <UrlComponent match={match} key={key} />,
    regexToMatch
  );

  return <div className="App">{output}</div>
};
  • match - regex match text
  • key - unique key for the match

Using multiple matches

Just use more than one component to match multiple patterns.

import { LinkItEmail, LinkItUrl } from 'react-linkify-it';

const App = () => (
  <div className="App">
    <LinkItUrl>
      <LinkItEmail>
        hello [email protected] https://google.com
      </LinkItEmail>
    </LinkItUrl>
  </div>
);

Using modern and legacy bundle

By default, when you import react-linkify-it, it will use a modern bundle meant for browsers which support RegExp Unicode property escapes.

If you are using babel-preset-env, or any bundler configuration which uses it (e.g. create-react-app, vite) with a browser which does not support RegExp Unicode property escapes, babel will transform the code to support the browsers resulting in a larger bundle.

If your setup does not use babel-preset-env and you would still like to support older browsers, you can use the legacy bundle by importing:

For javascript projects

import { linkIt, LinkIt } from "react-linkify-it/legacy";

For typescript projects (why?)

import { linkIt, LinkIt } from "react-linkify-it/dist/react-linkify-it.legacy.esm.min";

Note: Legacy bundle has a larger file size (~3.4Kb minziped).

Using a browser bundle

An umd build with legacy browser support can be used from Unpkg.

Acknowledgment

This project was made possible due to the incredible work done on the following projects:

License

This project is licensed under the MIT License - see the LICENSE file for details.

Details


Assets

  • react-linkify-it-1.0.0-npm.tgz

Download activity

  • Total downloads 0
  • Last 30 days 0
  • Last week 0
  • Today 0