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 🙏

© 2024 – Pkg Stats / Ryan Hefner

applause

v2.0.4

Published

Human-friendly replacements.

Downloads

202,703

Readme

Applause 👏

Build Status Version Prerequisite License: MIT Twitter: outa7iME

Pattern replacer that helps to create human-friendly replacements.

Try the playground, where you can test every single option of applause.

Install

First make sure you have installed the latest version of node.js (You may need to restart your computer after this step).

From NPM for programmatic use:

npm install applause

From Git:

git clone git://github.com/outaTiME/applause
cd applause
npm link .

Usage

Assuming installation via NPM, you can use applause in your application like this:

var fs = require('fs');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: 'foo',
      replacement: 'bar'
    }
  ]
};
var applause = Applause.create(options);
var contents = '@@foo';
var result = applause.replace(contents);
console.log(result.content); // bar

Options

patterns

Type: Array

Defines the patterns that will be used to replace the content input.

patterns.match

Type: String|RegExp

Indicates the matching expression.

If the match type is String, a simple variable search mechanism @@string is used (in any other case the default regexp replacement logic is used):

{
  patterns: [
    {
      match: 'foo',
      replacement: 'bar' // Replaces "@@foo" with "bar"
    }
  ]
}

patterns.replacement or patterns.replace

Type: String|Function|Object

Indicates the replacement for match. For more information about replacement, see String.replace.

You can specify a function as a replacement. In this case, the function will be invoked after the match has been made. The result of the function (return value) will be used as the replacement string.

{
  patterns: [
    {
      match: /foo/g,
      replacement: function () {
        return 'bar'; // Replaces "foo" with "bar"
      }
    }
  ]
}

Objects are also supported as replacement (a string representation of the object is created using JSON.stringify):

{
  patterns: [
    {
      match: /foo/g,
      replacement: [1, 2, 3] // Replaces "foo" with string representation of the array
    }
  ]
}

The replacement only resolves the special replacement patterns when using regexp to match.

patterns.json

Type: Object

If a json attribute is found in the pattern definition, the object is flattened using the delimiter concatenation and each key-value pair will be used for replacement (simple variable lookup mechanism and no regexp support).

{
  patterns: [
    {
      json: {
        key: 'value' // Replaces "@@key" with "value"
      }
    }
  ]
}

Nested objects are also supported:

{
  patterns: [
    {
      json: {
        key: 'value',  // Replaces "@@key" with "value"
        inner: {       // Replaces "@@inner" with string representation of the "inner" object
          key: 'value' // Replaces "@@inner.key" with "value"
        }
      }
    }
  ]
}

You can define functions for deferred invocations:

{
  patterns: [
    {
      json: function (done) {
        done({
          key: 'value'
        });
      }
    }
  ]
}

patterns.yaml

Type: String

If a yaml attribute is found in the pattern definition, it will be converted and then processed as json attribute.

{
  patterns: [
    {
      yaml: 'key: "value"' // Replaces "@@key" with "value"
    }
  ]
}

You can define functions for deferred invocations:

{
  patterns: [
    {
      yaml: function (done) {
        done('key: "value"');
      }
    }
  ]
}

patterns.cson

Type: String

If a cson attribute is found in the pattern definition, it will be converted and then processed as json attribute.

{
  patterns: [
    {
      cson: 'key: "value"'
    }
  ]
}

You can define functions for deferred invocations:

{
  patterns: [
    {
      cson: function (done) {
        done('key: "value"');
      }
    }
  ]
}

variables

Type: Object

This is the old way of defining patterns using a simple plain object (simple variable lookup mechanism and no regexp support). You can still use this, but for more control you should use the new way of patterns.

{
  variables: {
    'key': 'value' // Replaces "@@key" with "value"
  }
}

prefix

Type: String Default: @@

The prefix used for matching (avoid wrong replacements / easy way).

This only applies for simple variable lookup mechanism.

usePrefix

Type: Boolean Default: true

If set to "false", the pattern is matched without the "prefix" concatenation (this is useful when you want to lookup a simple string).

This only applies for simple variable lookup mechanism.

preservePrefix

Type: Boolean Default: false

If set to "true", the "prefix" is preserved in the target.

This only applies for simple variable lookup mechanism and when patterns.replacement is a string.

delimiter

Type: String Default: .

The delimiter used to flatten when using an object as a replacement.

preserveOrder

Type: Boolean Default: false

If set to "true", we preserve the order of definition of the patterns; otherwise the order will be ascending to avoid replacement problems such as "head" / "header" (regexp matches will be resolved at last).

Examples

Basic

File src/manifest.appcache:

CACHE MANIFEST
# @@timestamp

CACHE:

favicon.ico
index.html

NETWORK:
*

Node:

var fs = require('fs');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: 'timestamp',
      replacement: Date.now()
    }
  ]
};
var applause = Applause.create(options);
var contents = fs.readFileSync('./src/manifest.appcache', 'utf8');
var result = applause.replace(contents);
console.log(result.content); // The replaced output

Multiple matching

File src/manifest.appcache:

CACHE MANIFEST
# @@timestamp

CACHE:

favicon.ico
index.html

NETWORK:
*

File src/humans.txt:

              __     _
   _    _/__  /./|,//_`
  /_//_// /_|///  //_, outaTiME v.@@version

/* TEAM */
  Web Developer / Graphic Designer: Ariel Oscar Falduto
  Site: https://www.outa.im
  Twitter: @outa7iME
  Contact: afalduto at gmail dot com
  From: Buenos Aires, Argentina

/* SITE */
  Last update: @@timestamp
  Standards: HTML5, CSS3, robotstxt.org, humanstxt.org
  Components: H5BP, Modernizr, jQuery, Bootstrap, LESS, Jade, Grunt
  Software: Sublime Text, Photoshop, LiveReload

Node:

var fs = require('fs');
var pkg = require('./package.json');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: 'version',
      replacement: pkg.version
    },
    {
      match: 'timestamp',
      replacement: Date.now()
    }
  ]
};
var applause = Applause.create(options);
var contents = fs.readFileSync('./src/manifest.appcache', 'utf8');
var result = applause.replace(contents);
console.log(result.content); // The replaced output
contents = fs.readFileSync('./src/humans.txt', 'utf8');
result = applause.replace(contents);
console.log(result.content); // The replaced output

Cache busting

File src/index.html:

<head>
  <link rel="stylesheet" href="/css/style.css?rel=@@timestamp">
  <script src="/js/app.js?rel=@@timestamp"></script>
</head>

Node:

var fs = require('fs');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: 'timestamp',
      replacement: Date.now()
    }
  ]
};
var applause = Applause.create(options);
var contents = fs.readFileSync('./src/index.html', 'utf8');
var result = applause.replace(contents);
console.log(result.content); // The replaced output

Include file

File src/index.html:

<body>
  @@include
</body>

Node:

var fs = require('fs');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: 'include',
      replacement: fs.readFileSync('./includes/content.html', 'utf8')
    }
  ]
};
var applause = Applause.create(options);
var contents = fs.readFileSync('./src/index.html', 'utf8');
var result = applause.replace(contents);
console.log(result.content); // The replaced output

Regular expression

File src/username.txt:

John Smith

Node:

var fs = require('fs');
var Applause = require('applause');

var options = {
  patterns: [
    {
      match: /(\w+)\s(\w+)/,
      replacement: '$2, $1' // Replaces "John Smith" with "Smith, John"
    }
  ]
};
var applause = Applause.create(options);
var contents = fs.readFileSync('./username.txt', 'utf8');
var result = applause.replace(contents);
console.log(result.content); // The replaced output

Lookup for foo instead of @@foo

Node:

var Applause = require('applause');

var options = [
  {
    patterns: [
      {
        match: /foo/g, // Explicitly using a regexp
        replacement: 'bar'
      }
    ]
  },
  {
    patterns: [
      {
        match: 'foo',
        replacement: 'bar'
      }
    ],
    prefix: '' // Removing the prefix manually
  },
  {
    patterns: [
      {
        match: 'foo',
        replacement: 'bar'
      }
    ],
    usePrefix: false // Using the option provided
  }
];
options.forEach(function (option) {
  var applause = Applause.create(option);
  var contents = 'foo';
  var result = applause.replace(contents);
  console.log(result.content); // bar
});

Related

License

MIT © outaTiME