Socket
Socket
Sign inDemoInstall

@rpearce/flexible-string-replace

Package Overview
Dependencies
0
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @rpearce/flexible-string-replace

🧶 Safely replace any part of a string with anything. Example: useful for replacing substrings with JSX in React


Version published
Weekly downloads
362
increased by52.74%
Maintainers
1
Created
Weekly downloads
 

Readme

Source

flexible-string-replace

All Contributors npm version npm downloads Build Status Coverage Status Maintainability

Installation

$ npm i @rpearce/flexible-string-replace

or

$ yarn add @rpearce/flexible-string-replace

Usage

flexible-string-replace mirrors the functionality of String.prototype.replace with the following exceptions:

  • you can transform your match however you see fit
  • the return value is [ * ] – an Array of whatever type your Replacement is or returns. For example, if you pass it a function, then you'll get back a list of strings as well as your match transformations, whereas if you pass a string, you'll get back simply a list of strings with your replacement applied
  • the argument order is (Pattern, Replacement, String) so that if you'd like to curry the function and partially apply the first two arguments, you can then reuse those over and over again with different strings

Note: while these examples use some JSX, your matching function can return whatever you like.

import flexibleStringReplace from '@rpearce/flexible-string-replace'

const str = 'The rain in Spain falls mainly on the plain. Spain is nice.'
const searchText = 'spain'
const replacement = (match, offset) => <mark key={offset}>{match}</mark>


// usage with RegExp pattern
const pattern = new RegExp(searchText, 'igm')
flexibleStringReplace(pattern, replacement, str)
// [
//   'The rain in ',
//   <mark>Spain</mark>,
//   ' falls mainly on the plain. ',
//   <mark>Spain</mark>,
//   ' is nice.'
// ]


// usage with RegExp pattern and string Replacement
const pattern = 'Spain'
flexibleStringReplace(pattern, 'foobar', str)
// [
//   'The rain in ',
//   'foobar',
//   ' falls mainly on the plain. ',
//   'foobar',
//   ' is nice.'
// ]


// usage with String pattern (no match)
const pattern = 'spain'
flexibleStringReplace(pattern, replacement, str)
// ["The rain in Spain falls mainly on the plain. Spain is nice."]


// usage with String pattern (match)
const pattern = 'Spain'
flexibleStringReplace(pattern, replacement, str)
// [
//   'The rain in ',
//   <mark>Spain</mark>,
//   ' falls mainly on the plain. Spain is nice.',
// ]

Contributors

Thanks goes to these wonderful people (emoji key):


Robert Pearce

💻 🤔 ⚠️ 💡 📖

This project follows the all-contributors specification. Contributions of any kind welcome!

Keywords

FAQs

Last updated on 15 Mar 2020

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc