Giter VIP home page Giter VIP logo

polyfill-service's Introduction

Polyfill service

Build Status

polyfill makes web development less frustrating by selectively polyfilling just what the browser needs. Use it on your own site, or as a service. For usage information see the hosted service, which formats and displays the service API documentation located in the docs folder.

Installing as a service

To install polyfill as a service:

  1. Install git and Node on your system
  2. Clone this repository to your system (git clone [email protected]:Financial-Times/polyfill-service.git)
  3. Run npm install

To run the app for development:

Install nodemon, and run nodemon -e js,json service/index.js from the root of the working tree. This will watch your filesystem and automatically restart if you make any changes to any of the app source code or polyfill config files.

To run the app for production:

Run npm start. This will run the service using forever, which runs the process in the background, monitors it and restarts it automatically if it dies. It doesn't watch the filesystem for changes and you won't see any console output.

In either case, once the service is running, navigate to http://localhost:3000 in your browser

Alternatively, deploy straight to Heroku:

Deploy

For an HTTP API reference, see the hosted service documentation.

Using as a library

Polyfill service can also be used as a library in NodeJS projects. To do this:

  1. Add this repo as a dependency in your package.json
    e.g. npm install "Financial-Times/polyfill-service" --save-dev
  2. Rebuild your project using npm install
  3. Use the API from your code

Library API reference

getPolyfillString(options) (method)

Returns a bundle of polyfills as a string. Options is an object with the following keys:

  • uaString: String, required. The user agent to evaluate for polyfills that should be included conditionally
  • minify: Boolean, optional. Whether to minify the bundle
  • type: String, optional. 'js' or 'css', defaults to js
  • features: Array, optional. The list of features that are to be considered for polyfill inclusion. If not supplied, all default features will be considered. Each feature must be in the form of an object with the following properties:
    • name: String, required. Name of features, matching a folder name in the polyfills directory, or a known alias
    • flags: Array, optional. Array of flags to apply to this feature (see below)

Flags that may be applied to polyfills are:

  • gated: Wrap this polyfill in a feature-detect, to avoid overwriting the native implementation
  • always: Include this polyfill regardless of the user-agent

Example:

require('polyfill-service').getPolyfillString({
	uaString: "Mozilla/5.0 (Windows; U; MSIE 7.0; Windows NT 6.0; en-US)",
	minify: true,
	features: [
		{name:"Element.prototype.matches", flags:['always', 'gated']},
		{name:"modernizr:es5array"}
	]
});

getPolyfills(options) (method)

Returns a list of features whose configuration matches the given user agent string. Options is an object with the following keys:

  • uaString: String, required. The user agent to evaluate for features that should be included conditionally
  • features: Array, optional. The list of features that are to be considered for polyfill inclusion. If not supplied, all default features will be considered. Each feature must be in the form of an object with the following properties:
    • name: String, required. Name of features, matching a folder name in the polyfills directory, or a known alias
    • flags: Array, optional. Array of flags to apply to this feature (see above in getPolyfillString)

Example:

require('polyfill-service').getPolyfills({
	uaString: "Mozilla/5.0 (Windows; U; MSIE 7.0; Windows NT 6.0; en-US)",
	features: [
		{name:"Element.prototype.matches", flags:['always', 'gated']},
		{name:"modernizr:es5array"}
	]
});

getAllPolyfills() (method)

Return a list of all the features with polyfills as an array of strings. This list corresponds to directories in the /polyfills directory.

Example:

require('polyfill-service').getAllPolyfills();

polyfill-service's People

Contributors

jonathantneal avatar samgiles avatar triblondon avatar lvivier avatar mathiasbynens avatar alrra avatar jonathanong avatar juandopazo avatar kaelig avatar matthew-andrews avatar wheresrhys avatar arthurvr avatar daniel-hug avatar mdevils avatar ondras avatar aintgoin2goa avatar dpen2000 avatar

Watchers

Serhii Tatarintsev avatar James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.