Package Exports
- @igor.dvlpr/str-is-in
- @igor.dvlpr/str-is-in/dist/index.mjs
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@igor.dvlpr/str-is-in) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
" ".IsIn([ ])
๐งต Provides ways of checking whether a String is present in an Array of Strings using custom Comparators. ๐
๐ Support further development
I work hard for every project, including this one and your support means a lot to me!
Consider buying me a coffee. โ
Thank you for supporting my efforts! ๐๐
![]()
@igorskyflyer
๐ต๐ผ Usage
Install it by executing:
npm i "@igor.dvlpr/str-is-in"
๐คน๐ผ API
ComparatorCallback
A type named ComparatorCallback
is exposed and used as a signature for the comparator
parameter of the strIsIn()
function.
type ComparatorCallback = (entry: string, value: string) => boolean
strIsIn()
strIsIn(value: string, entries: string[], comparator?: ComparatorCallback): boolean
Checks whether the given String is present in the provided array of Strings.
findMatch
findMatch.full(value: string, entries: string[]): string
Performs a case-insensitive and full-matching search for a given value inside an array of values and returns the found match (with the original case being preserved). If none is found an empty string is returned.
findMatch.partial(value: string, entries: string[]): string
Performs a case-insensitive and partial-matching search for a given value inside an array of values and returns the found match (with the original case being preserved). If none is found an empty string is returned.
Examples
import { strIsIn, findMatch } from '@igor.dvlpr/str-is-in'
// #1 - use default Comparator, non-existent string, full match
console.log(strIsIn('bin', ['abc', 'cde', 'def', 'binary'])) // prints false
// #2 - use default Comparator, existing string, full match
console.log(strIsIn('bin', ['abc', 'cde', 'bin', 'adc'])) // prints true
// #3 - empty array passed
console.log(strIsIn('bin', [])) // prints false
// #4 - custom Comparator, partial match
console.log(strIsIn('bin', ['abc', 'cde', 'def', 'binary'], (entry, value) => entry.indexOf(value) > -1)) // prints true
// #5 - custom Comparator, partial match
console.log(strIsIn('bin', ['abc', 'cde', 'def', 'HellobinaryWorld'], (entry, value) => entry.indexOf(value) > -1)) // prints true
// #6 - custom Comparator, partial match, non-existent string
console.log(
strIsIn('t', ['abc', 'cde', 'def', 'HellobinaryWorld'], (entry, value) => entry.toLowerCase() === value.toLowerCase())
) // prints false
// #7 - custom Comparator, partial match, existing string, case-insensitive
console.log(strIsIn('WORLD', ['abc', 'cde', 'def', 'world'], (entry, value) => entry.toLowerCase() === value.toLowerCase())) // prints true
// #8 - custom Comparator, partial match, case-insensitive
console.log(
strIsIn(
'WORLD',
['abc', 'cde', 'def', 'HellobinaryWorld'],
(entry, value) => entry.toLowerCase().indexOf(value.toLowerCase()) > -1
)
) // prints true
// #9 - full match-finding
console.log(findMatch.full('WORLD', ['abc', 'cde', 'world', 'HellobinaryWorld'])) // prints 'world'
// #10 - partial match-finding
console.log(findMatch.partial('WORLD', ['abc', 'cde', 'world-foo', 'HellobinaryWorld'])) // prints 'world-foo'
๐ชช License
Licensed under the MIT license which is available here, MIT license.
๐งฌ Related
๐งฒ Provides ways of properly checking if a path exists inside a given array of files/directories both on Windows and UNIX-like operating systems. ๐บ
๐งฐ Provides ways of testing whether a given value can be a valid file/directory name. ๐
๐ An NPM package for fetching Windows registry keys. ๐
๐ฆ ExtendableString allows you to create strings on steroids that have custom transformations applied to them, unlike common, plain strings. ๐ช
๐ NormalizedString provides you with a String type with consistent line-endings, guaranteed. ๐ฎ
Provided by Igor Dimitrijeviฤ (@igorskyflyer).