npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@freedomsex/text-censor

v0.0.4

Published

Censor or highlight words.

Downloads

9

Readme

Text Censor

Модуль для простого цензурирования сообщений. Сам по себе модульный, поддерживает расширение плагинами. Фильтры, в том числе встроенные, добавляются через плагины. Есть возможность добавлять и удалять фильтры используя соответствующие методы add и delete.

Фильтры

Грубо говоря - это обычное регулярное выражение. Чтобы иметь возможность управлять регуляркой, ему дается имя, состояние и обработчик. Состояние позволяет включить или выключить фильтр. По имени фильтр можно удалить из списка, например. Обработчик, это функция, класс или модуль, которые включают логику о том, что делать с текстом, если сработал паттерн регулярного выражения. Для каждого экземпляра можно настроить свой список фильтров.

Обработчик

Функция, класс или модуль, которые включают логику обработки текста. Например, найденный текст можно заменить звездочками. Количество звездочек можно настроить. Либо это будет стандартно 3 звездочки, либо количество равное длине слова. Также можно установить фильтр подсвечивающий найденное слово, либо заменяющий на стандартный текст заглушку. Для каждого фильтра можно добавить свой обработчик.

Обработчик должен иметь только один метод replace - функция, которая под капотом подставляется вторым аргументом в одноименную String.prototype.replace(). От вас нужена только сама функция, если хотите добавить свою логику. Либо используйте имеющиеся обработчики.

Плагин

Это очень простые файлы, которые содержат лишь голый паттерн регулярки и метод install - который добавляет новый фильтр в список фильтров. Метод получает экземпляр модуля и опции в виде параметров.

Логику самого плагина вы вправе писать какую угодно. Чаще всего через плагины добавляются новые фильтры, по одному на каждый плагин. Хорошим тоном будет добавить паттерн как отдельное свойство плагина pattern - тогда его будет легко получить из плагина в любой другой библиотеке или внешнем модуле.

Использование

var TextCensor = new Censor();
var prepared = TextCensor.filter('Плохой текст, [email protected] - емайл');
// prepared - Плохой текст, ****************** - емайл

Конструтор принимает два необязательных параметра handler и filters. Первый устанавливает глобальный обработчик для всех фильтров. Второй заменяет собой список предустановленных фильтров. Можно просто отключить ненужные и добавить необходимые фильтры, а можно установить полностью свой список.

$filters

Объект для работы с фильтрами. Через него можно управлять списком фильтров

add(name, filter) - добавить фильтр

get(name) - получить

toggle(name) - включить/выключить

enable(name) - включить

disable(name) - выключить

Изменить обработчики

var handler = new handlers/Placeholder();
var Censor = new Censoring(handler);

По умолчанию просто звездочки. Но даже сами звездочки можно перенастроить.

Свой список

var Filters = new Filters();
// ... Настроили список как хотим
var Censor = new Censoring(null, Filters);

Когда очень нужны только свои фильтры или индивидуальные обработчики вместо дефолтного. Любые другие причины.