Skip to content

Latest commit

 

History

History
386 lines (290 loc) · 9.25 KB

README.md

File metadata and controls

386 lines (290 loc) · 9.25 KB

asset-pipeline

Transform your asset path like a boss

Features

  • A path/url builder to create your path easily
  • Handle cache-breaking
  • Create multiple outputs
  • Use tag and priority to choose your output path
  • Extensible with plugins
  • Save results into a manifest (with ManifestPlugin)
  • Perform move/copy/symlink (with FsPlugin)

Example

import { AssetPipeline } from "asset-pipeline";

const pipeline = new AssetPipeline()

pipeline.rules.saltKey = "saltKey"

pipeline.rules.cacheBreak = true

// Set origin (Rendered: http://mycdn.com/)
pipeline.host.setOrigin("http://mycdn.com")

// Set pathname (Rendered: http://mycdn.com/public)
pipeline.host.setPathname("public")

// Create a source object a path relative to cwd
const APP_PATH = pipeline.createPath("app")

pipeline.files
  // Include files to fetch
  .include(APP_PATH.join("scripts/main.ts"))
  .include(APP_PATH.join("styles/main.styl"))
  .include(APP_PATH.join("views/**/*.html.ejs"))
  .include(APP_PATH.join("assets/**/*"))

  // Exclude files with underscores at the begining
  .exclude(APP_PATH.join("views/**/_*.html.ejs"))

// Typescript rule
pipeline.rules
  .add(APP_PATH.join("scripts/main.ts"))
  .extension(".js")
  .keepDirectory(false)

// Add another output
pipeline.rules
  .add(APP_PATH.join("scripts/main.ts"))
  .path("main.esm.js")
  .tag("esm")
  .priority(-1)

// Stylus rule
pipeline.rules
  .add(APP_PATH.join("styles/main.styl"))
  .extension(".css")
  .keepDirectory(false)

// Views rule
pipeline.rules
  .add(APP_PATH.join("views/**/*.html.ejs"))
  .extension(".html")
  .relative(APP_PATH.join("views"))
  .cachebreak(false)

// Assets rule
pipeline.rules
  .add(APP_PATH.join("assets/**/*"))
  .relative(APP_PATH)

// Resolve patterns and transform paths
pipeline.fetch()

// Add alias
pipeline.alias("app/scripts")
pipeline.alias("app/styles")
pipeline.alias("app/views")
pipeline.alias("app/assets")

// Logs
console.log(pipeline.resolver.getPath("app/scripts/main.ts")) // /main-b325d4632fa412.js
console.log(pipeline.resolver.getPath("app/scripts/main.ts", "esm")) // /main.esm-f42dac1324a21d.js

console.log(pipeline.resolver.getURL("app/scripts/main.ts")) // http://mycdn.com/main-b325d4632fa412.js
console.log(pipeline.resolver.getOutputPath("app/scripts/main.ts")) // public/main-b325d4632fa412.js

console.log(pipeline.resolver.getPath("main.ts")) // /main-b325d4632fa412.js
console.log(pipeline.resolver.getURL("main.ts")) // http://mycdn.com/main-b325d4632fa412.js
console.log(pipeline.resolver.getOutputPath("main.ts")) // public/main-b325d4632fa412.js

console.log(pipeline.resolver.getPath("app/assets/images/image.jpg")) // /images/image-aedaed23aed453.jpg
console.log(pipeline.resolver.getPath("images/image.jpg")) // /images/image-aedaed23aed453.jpg

Documentation

Pipeline

// Display logs (Default: false)
pipeline.logging = false

// Fetch files and apply transformations
pipeline.fetch(forceResolve?)

// Append files to transform
pipeline.append(forceResolve?)

// Get options from plugins
pipeline.options("pluginOptions")

// Register a new plugin
await pipeline.plugin({
  name: "myPlugin",
  setup(pipeline: Pipeline) {
    // Do something
  }
})

// Create a path builder
const app = pipeline.createPath("app")
app.join("scripts").os() // app/cripts

// Listen when files and patterns are resolved
pipeline.events.on("resolved", (paths) => {
  console.log(paths)
})

// Listen when paths ared transformed
pipeline.events.on("transformed", (results) => {
  console.log(results)
})

FileList

// Add file path or pattern
pipeline.files.include("app/scripts/*.ts")
pipeline.files.include("app/assets/image.jpg")

// Ignore file path or pattern
pipeline.files.exclude("app/scripts/_*.ts")

// Add non-existing file path
pipeline.files.exclude("app/scripts/generated/PAGE.ts")

// Resolve paths and patterns
pipeline.files.resolve()

Transformer

// Set salt key
pipeline.saltKey = "saltKey"

// Toggle cachebreak
pipeline.cachebreak = false

// Create a transform rule for a pattern
pipeline.rules.add("app/scripts/*.ts") // TransformRule

// Delete a transform rule for a pattern
pipeline.rules.delete("app/scripts/*.ts")

// A transform exists for this path or not
pipeline.rules.match("app/scripts/main.ts")

// Transform an array of paths
pipeline.rules.transform(["app/scripts/main.ts"]) // TransformResult[]

Transform Rule

pipeline.rules.add("app/scripts/main.ts")

// Rewrite filemae
.name("bundle.ts") // will create public/app/scripts/bundle.ts

// Set extension
.extension(".js") // will create public/app/scripts/bundle.js

// Rewrite directory
.directory("scripts") // will create public/scripts/bundle.js

// Keep directory
.keepDirectory("scripts") // will create public/scripts/bundle.js

// Add base directory
.baseDirectory(false) // will create public/bundle.js

// Add relative path
.relative("resources") // will create public/bundle.js

// Add relative path
.cachebreak(true) // will create public/bundle-1ae2da2ed1ae231.js

// Set path
.path("main.js") // will create public/main-1ae2da2ed1ae231.js

// Set tag
.tag("default")

// Set tag
.priority(0)

// Apply transformation
.apply("app/scripts/main.ts", {
  cachebreak: true,
  saltKey: "saltKey"
}) // TransformResult

// Add another rule for the same file
pipeline.rules.add("app/scripts/main.ts")
  .path("main.esm.js")
  .tag("esm")
  .priority(-1) // will create public/app/scripts/main.esm.js

Resolver

// Output path builder (Default: "public")
pipeline.output.set("public")

// Host url builder (Default: origin="", pathname="/")
pipeline.host.set("http://mycdn.com/")

// Register alias. Instead of using "app/scripts/main.ts" as input, you can write "main.ts"
pipeline.resolver.alias("app/scripts")

// Return an array of outputs. If tag is given, returns outputs matching the tag
pipeline.resolver.resolve("main.ts") // "/main.js"
pipeline.resolver.resolve("main.ts", "anyTag") // "/main.js"
pipeline.resolver.resolve("main.ts", "esm") // "/main.esm.js"

// Get path. If tag is given, return output path matching the tag
pipeline.resolver.getPath("main.ts") // "/main.js"
pipeline.resolver.getPath("main.ts", "anyTag") // "/main.js"
pipeline.resolver.getPath("main.ts", "esm") // "/main.esm.js"

// Get URL. If tag is given, return output URL matching the tag
pipeline.resolver.getUrl("main.ts") // "http://mycdn.com/main.js"
pipeline.resolver.getUrl("main.ts", "anyTag") // "http://mycdn.com/main.js"
pipeline.resolver.getUrl("main.ts", "esm") // "http://mycdn.com/main.esm.js"

// Get path. If tag is given, return output path matching the tag
pipeline.resolver.getOutputPath("main.ts") // "public/main.js"
pipeline.resolver.getOutputPath("main.ts", "anyTag") // "public/main.js"
pipeline.resolver.getOutputPath("main.ts", "esm") // "public/main.esm.js"

// Try to find the  original input
pipeline.resolver.findInputPath("main.js") // TransformResult

// Try to find the  original input
pipeline.resolver.filter(([input, transformed]) => {
  return input === "app/scripts/main.ts"
}) // [TransformResult]

Plugin - FileSystem

const { FsPlugin } = require("asset-pipeline")
pipeline.plugin(FsPlugin)

const fs = p.options("fs")

// Number of items by chunk to perform asynchronously
fs.chunkCount = 15

// Register a move
fs.move("path_or_pattern")

// Register a copy
fs.copy("path_or_pattern")

// Register a symlink
fs.symlink("path_or_pattern")

// Ignore
fs.ignore("path_or_pattern")

// Perform copy/move/symlink to updated files only (based on mtime)
fs.apply(force?) // Force

// Listen when a new file is moved/copied/symlinked
fs.events.on("newfilecopied", ([from, to]) => {
  console.log(from, to)
})

// Same event
pipeline.events.on("newfilecopied", ([from, to]) => {
  console.log(from, to)
})

Plugin - Manifest

const { ManifestPlugin } = require("asset-pipeline")
pipeline.plugin(ManifestPlugin)

const manifest = p.options("manifest")

// Save on disk (default: true)
manifest.saveOnDisk = true

// Override pipeline
manifest.set({
  "saltKey": "",
  "date": "2021-02-04T18:43:26.338Z",
  "aliases": [
    "app/scripts"
  ],
  "entries": [
    [
      "app/assets/image.jpg",
      {
        "path": "assets/image.jpg",
        "tag": "default",
        "priority": 0
      }
    ],
    [
      "app/scripts/main.ts",
      {
        "path": "main.js",
        "tag": "default",
        "priority": 0
      }
    ],
    [
      "app/scripts/main.ts",
      {
        "path": "main.esm.js",
        "tag": "esm",
        "priority": 0
      }
    ]
  ]
})

// Set manifest path
manifest.path.set("tmp/manifest.json")

// Check if manifest is created
manifest.exists()

// Save manifest
manifest.save()

// Read manifest and override pipeline
manifest.read()

// Remove manifest on disk
manifest.delete()

More examples