Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dhaiwat10/react-link-preview

A React library that generates beautiful previews for your links.
https://github.com/dhaiwat10/react-link-preview

Last synced: 1 day ago
JSON representation

A React library that generates beautiful previews for your links.

Awesome Lists containing this project

README

        

# React Link Preview

A React component that renders beautiful, fully-customizable link previews.

![Demo](demo.gif)

Follow @dhaiwat10

[![npm version](https://badge.fury.io/js/%40dhaiwat10%2Freact-link-preview.svg)](https://badge.fury.io/js/%40dhaiwat10%2Freact-link-preview)
![package downloads](https://img.shields.io/npm/dt/@dhaiwat10/react-link-preview)
![CI](https://img.shields.io/github/workflow/status/dhaiwat10/react-link-preview/CI)

Demo

## How to use

**Install the package:**

`yarn add @dhaiwat10/react-link-preview`

`npm install @dhaiwat10/react-link-preview`

**Import and render the preview:**

```js
import { LinkPreview } from '@dhaiwat10/react-link-preview';

const Home = () => {
return ;
};
```

If the component renders nothing, it means that no metadata could be scraped for the URL. Provide a `fallback` component if you don't want to render `null`.

## Important

This package uses a Heroku [proxy (open-source)](https://github.com/dhaiwat10/rlp-proxy) to get around CORS issues. The public proxy receives a lot of traffic (+ there is a rate limit) and is not recommended for production use.

## Recommended workflow (for production)

- Please [fork the proxy repo](https://github.com/dhaiwat10/rlp-proxy) and host your own copy of it.
- You can then use the `customFetcher` prop to pass a fetcher function that fetches data from _your_ proxy. The `LinkPreview` will now use your proxy as the data source. More details below.

## API (Available props)

You can pass the following props to the `LinkPreview` component.

### `url` (string)

The URL for which you want to generate the link preview.


### `customFetcher?` (function)

A function that takes in a `url` & fetches data from a proxy/server. The function should return a Promise that resolves to an object with the following structure:

```js
{
title: string | null;
description: string | null;
image: string | null;
siteName: string | null;
hostname: string | null;
}
```

You can use any data-source as you like as long as the `customFetcher` function returns a Promise that resolves to an object with the above structure.

[Example](src/components/LinkPreview/LinkPreview.stories.tsx#L54)


### `fallback?` (JSX.Element / any valid JSX)

A fallback component which will be rendered if a link preview could not be generated.


### `fallbackImageSrc` (string)

A fallback image src/URL which will be used if there was no image found for the URL.

### `explicitImageSrc` (string)

The src that will be used for the image regardless of what the data source returns.

### `showLoader?` (boolean)

Whether you want to display the default loading skeleton or not.


### `customLoader?` (JSX.Element / any valid JSX)

Custom loader that will be displayed in place of the default loader.


### `backgroundColor?` (string)

Background color of the card.


### `primaryTextColor?` (string)

Color of the primary text (title).


### `secondaryTextColor?` (string)

Color of the secondary text (description, URL, domain name).


### `borderColor?` (string)

Color of the border of the card.


### `className?` (string)

Any custom CSS class that you want to apply to the card.


### `width?` (string or number)

Width of the card.


### `height?` (string or number)

Height of the card.


### `margin?` (string or number)

Margin around the card.


### `descriptionLength?` (number)

Length of the description in the card. (number of characters)


### `borderRadius?` (string or number)

Border radius of the card.


### `imageHeight?` (string or number)

Height of the image.


### `textAlign?` ( _left_, _right_ or _center_)

Alignment of the text.


### `openInNewTab?` (boolean)

Where the link is opened (new tab or current tab).


### `showPlaceholderIfNoImage?` (boolean)

Whether the placeholder image is displayed in case no image could be scraped.

___

Props marked with **?** are **optional**.