GitXplorerGitXplorer
c

profane

public
30 stars
1 forks
0 issues

Commits

List of commits on branch main.
Unverified
f8f53b946c81d4561aeecce2a6df5dba86a68df6

Typo.

ccpojer committed 2 years ago
Unverified
36e22468c61e0b4b9776bb98a75a0107d2121b08

Add FUNDING.yml.

ccpojer committed 2 years ago
Unverified
514eea6fdfeaf8db0ac2bdb491e87e8e467b3620

Add back `main` because eslint does not yet support `exports`…

ccpojer committed 2 years ago
Unverified
a6023b801a310279dcfbcff9367ebb81b4990c38

Update packages, publish as ESM only.

ccpojer committed 2 years ago
Unverified
b7ed569fee98fa28e54f0f4cdccbcb0a0c3067f5

Rename org to `@nkzw`.

ccpojer committed 2 years ago
Unverified
6e139fc7b6d29cb770963bbedf79a65f9d5d0e4d

1.0.2

ccpojer committed 2 years ago

README

The README file for this repository.

@nkzw/profane

Zero dependency profanity detector based on Swearjar and Profane.

Note: Some examples may contain offensive language for illustration purposes.

Installation

npm install @nkzw/profane

Usage

new Profane(options?)

Create a new instance:

import Profane from 'profane';

const profane = new Profane();

check(text: string): boolean

Check if a text matches the word list:

profance.check('Hell no'); // true
profance.check('H3ll no'); // true
profane.check('Banana Banana Banana'); // false

censor(censored: string, replacement?: string): string;

Censor words matching the word list:

profane.censor('Hell no'); // '**** no'
profane.censor('Hell no', '•'); // '•••• no'

getWordFrequencies(text: string): Record<string, number>;

Get the word frequencies of words matching the word list:

```js
const frequencies = profane.getWordFrequencies('horniest hornet fart');
{
  "horniest": 1,
  "fart": 1
}

getCategoryFrequencies(text: string): Record<string, number>;

Get the category frequencies of words matching the word list:

const frequencies = profane.getCategoryFrequencies('horniest hornet fart');
{
  "inappropriate": 1,
  "sexual": 1
}

Options

words: Record<string, ReadonlyArray<string>>

You can configure your Profane instance with a custom word list by supplying an object with word definitions:

const profane = new Profane({
  words: {
    happy: ['inappropriate'],
    awesome: ['elated'],
  },
});

profane.check('Mr. Happy is awesome'); // true
profane.getCategoryFrequencies('Mr. Happy is awesome'); // {inappropriate: 1, elated: 1}

You can receive a copy of the word list through the getWordList() function:

import { getWordList } from '@nkzw/profane';

getWordList(); // Record<string, ReadonlyArray<string>>

normalize?: boolean

Determines whether to normalize Leet or not. Defaults to true'.

new Profane({ normalize: false }).check('H3ll'); // false
new Profane({ normalize: true }).check('H3ll'); // true

wholeWordsOnly?: boolean

Whether to match only on whole words or not. Defaults to false'.

new Profane({ wholeWordsOnly: false }).check('shell'); // true
new Profane({ wholeWordsOnly: true }).check('shell'); // false

Updates to the word list

The default word list was lifted from Swearjar and may be out-of-date. Please feel free to send Pull Requests with new and updated definitions.