Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

normalize-transforms

Package Overview
Dependencies
Maintainers
1
Versions
20
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

normalize-transforms

Transforms for normalize-walker

  • 0.1.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
2
increased by100%
Maintainers
1
Weekly downloads
 
Created
Source

Walker Transforms

These are all the transforms available for both the normalization proxy and nlz-build. Unlike Component, Browserify, and other build systems, transforms are included automatically, and all transforms are stored in a single repository. There are a couple of reasons for this:

  • This middleware system is a more complicated than other middleware systems:

    • The use of Koa-based upstream/downstream is quite complex
    • Order of middleware is very important, especially when handling upstreams/downstreams
    • Transforms are not orthogonal to another, so we have to make sure each plugin interacts with each other well. This is more difficult than creating the transforms themselves.
  • The purpose of normalization is for everyone to be on the same page. It's counter productive to have different semantics for the same transform across applications.

PRs for additional transforms are welcomed as long as there's a valid use-case and people would actually use it.

How Transforms Work

Given a source file such as template.html, the walker transforms the file based on additional .<extensions>. For example, template.html.js will export the HTML string as a JS string. This is superior because:

  • It's compatible with HTTP servers
  • The transforms used are explicitly shown
  • It allows you to use the same source file in multiple ways without configuration

For example, template.jade.js would return a jade render function whereas template.jade.html.js will return the jade template as a compiled string.

You can also compose multiple transforms together. For example, .jade.html is its own transform and so is .html.js. Together, .jade.html.js has a very specific meaning. In other words, .jade.html.js is a composition of transforms!

Unlike other build systems and package managers, transforms have the ability to inject required dependencies into your application, making development easier in general. For example, to use .jade.js, you need to jade runtime. The Jade transform will automatically inject the runtime by compiling your jade template to something like this:

var jade = require('https://nlz.io/github/visionmedia/jade/1/lib/runtime.js')

module.exports = function template(locals) {
  // compiled jade
}

Transforms

CSS

Autoprefixer

All CSS is automatically prefixed using autoprefixer. No extensions are necessary. The default options are used.

Rework

A subset of specification compliant rework plugins are included. These are essentially a subset of myth. These are:

JS

ES6 Modules

All ES6 modules are automatically transpiled to CommonJS modules using es6-module-jstransform. This will be disabled by default once ES6 modules are widely supported by browsers.

Regenerator

All code that uses generators are automatically transformed using regenerator. This will be disabled by default once generators are widely supported by browsers.

.<mime:text/*>.js

All extensions whose corresponding MIME type is text/* are automatically transformed to a JS string using JSON.stringify() unless superceded by another transform.

This is included in normalize-walker.

.json.js

Transforms JSON files to a JS object.

This is included in normalize-walker.

.jade.html

Compile jade templates to an HTML string.

.jade.js

Compile jade templates to a function.

.(md|markdown).html

Compile markdown templates to an HTML string using marked.

.jsx.js

Compile React .jsx templates to JS.

.html.domify.js

Compile an HTML string to an element using domify. This is useful for web components and templates.

var template = require('./template.html.domify.js')

document.body.appendChild(template.cloneNode(true))

FAQs

Package last updated on 06 May 2014

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc