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

koa-pug-jade

v3.0.1

Published

A Pug middleware for Koa

Downloads

3

Readme

Koa-pug

Node version NPM version Dependency Status Travis CI Codecov

A Pug middleware for Koa.

How to use

npm install koa-pug --save
const koa = require('koa')
const app = koa()

const Pug = require('koa-pug')
const pug = new Pug({
  viewPath: './views',
  debug: false,
  pretty: false,
  compileDebug: false,
  locals: global_locals_for_all_pages,
  basedir: 'path/for/pug/extends',
  helperPath: [
    'path/to/pug/helpers',
    { random: 'path/to/lib/random.js' },
    { _: require('lodash') }
  ],
  app: app // equals to pug.use(app) and app.use(pug.middleware)
})

pug.locals.someKey = 'some value'

app.use(function* () {
  this.render('index', locals_for_this_page, true)
})

With vhost:

const koa = require('koa')
const vhost = require('koa-vhost')
const Pug = require('koa-pug')
const _ = require('lodash')

const server = koa()
const server1 = koa()
const server2 = koa()

const config = {
  locals: {
    title: 'Koa Demo'
  }
}

var pug1 = new Pug(_.assign({}, config, {
  viewPath: './views1/'
}))

var pug2 = new Pug(_.assign({}, config, {
  viewPath: './views2/'
}))

pug1.use(server1)

server1.use(function* (next) {
  this.render('index')
})

pug2.use(server2)

server2.use(function* (next) {
  this.render('index')
})

server.use(vhost('test1.app.dev', server1))
server.use(vhost('test2.app.dev', server2))

koa@2

  • Use pug.use(app) or new Pug({ app }), DON'T use app.use(pug.middleware)
  • Use ctx.render() instead of this.render()
new Pug({ app: app })
// or
pug.use(app)

Options

viewPath: where Pug templates be stored. Default is process.cwd().

pretty and compileDebug: see Pug's docs. Default is false.

debug: shorthand for pretty and compileDebug. Default is false.

locals: variables that will be passed to Pug templates.

noCache: use cache or not. Cache could make template rendering 100x faster than without cache. It useful for production, but useless for development (pages would not be updated untill Koa restarted). In most case, noCache: process.env === 'development' should be enough. If wanna control it in production for specific page, use render()'s noCache instead.

helperPath: String or Array, where to load helpers, and make them available on all .pug. In Array, you can use object to assgin name for module, eg: { random: './path/to/random.js' }.

basedir: help Pug to identify paths when using extends with absolute paths.

Methods and Properties

use

Binding render function to app.context. See Koa's doc.

const Pug = require('koa-pug')
const pug = new Pug()
// `new Pug({ app })` equals to
pug.use(app)

app.use(function* () {
  this.render('h1 Hello, #{name}', { name: 'Pug' }, { fromString: true })
})

render

Render string or template file and return string directly.

const pug = new Pug()
pug.render('h1 Hello, #{name}', { name: 'Pug' }, { fromString: true })
// outpus:
// <h1>Hello Pug</h1>

// rendering file
const pug = new Pug({ viewPath: 'path/to/view' })
// render path/to/view/hello.pug
pug.render('hello', { name: 'Pug' })

middleware (deprecated)

The middleware for configuring Koa's context.

const Pug = require('koa-pug')
const pug = new Pug()
app.use(pug.middleware)

options

Options for rendering views.

// Passing options in construction
const pug = new Pug({
  debug: process.env.NODE_ENV === 'development',
  ...
})

// Change options when needed
if (NO_CACHE) {
  pug.options.noCache = false
}

/**
 * Reset options to default:
 * {
 *   compileDebug: false,
 *   pretty: false
 * }
 */
pug.options = {}

locals

An object of locals that will be passed to all views.

// Setting some locals for different envs
if (process.env.NODE_ENV === 'development') {
  pug.locals.debug = DEBUG_DATA
}

// Mass assignment
_.assign(pug.locals, LOCALS_1, LOCALS_2, ...)

// You can override it by assigning an object ot it
pug.locals = {
  key: value,
  foo: 'bar'
}

// Remove all locals
pug.locals = {}

ctx.render(tpl, locals, options, noCache)

Render template, and set rendered template to this.body.

tpl: the path of template that based on viewPath, .pug is optional.

locals: locals for this page. Optional. If options or noCache presented, please use {}, undefined or null for empty locals. locals will merge up with ctx.state(koa@2) or this.state(koa@1). Middlewares can assign locals to ctx.state.

options: override global default options for this page. Only assigning an object or a boolean to it will take effects.

options.fromString: fromString only available in ctx.render, by assigning a true value, Pug will not treat tpl as a path: ctx.render('h1 Hello, #{name}'). Templates rendered with fromString: true will not be stored in cache.

noCache: use cache or not. Notes: 1. overrides global noCache; 2. won't affect other pages.

If options is set to true or false, it will be treated as noCache, and noCache will be ignored. For example, render(tpl, locals, true) equals to render(tpl, locals, {}, true), and render(tpl, locals, true, false) will skip cache and re-compile template.

options and noCache are optional.

basedir

If you encounter this error, Error: the "basedir" option is required to use "extends" with "absolute" paths, try to set basedir like this:

const pug = new Pug({
  viewPath: 'path/to/views',
  basedir: 'path/for/pug/extends'
})

or

app.use(function* () {
  this.render('index', locals, { basedir: 'path/for/pug/extends' })
})

Content-Type

koa-pug sets content-type to text/html automatically. if you wanna change it, do like this:

this.render('index')
this.type = 'text/plain'

Global Helpers

By setting helperPath, koa-pug will load all the modules that under sepecified folxder, and make them available on all templates.

helperPath also could be an array including folders, files path, even moduleName: 'path/to/lib.js mapping object. Also support node module as a helper, just like: '_': require('lodash')

Defining Helper

// format-date.js
module.exports = function (input) {
  return (input.getMonth() + 1) + '/' + input.getDate() + '/' + input.getFullYear()
}

It equals to:

// whatever.js
module.exports = {
  moduleName: 'formatDate',
  moduleBody: function (input) {
    return (input.getMonth() + 1) + '/' + input.getDate() + '/' + input.getFullYear()
  }
}

In Pug:

p= formatDate(new Date())

How koa-pug resolves views

For example, there's a folder structure like this:

- views
  |--- foo.pug
  |--- foo/
    |--- index.pug
  |--- bar/
    |--- index.pug
  |--- baz

For this.render('foo'), koa-pug will render foo.pug, not foo/index.pug (file has higher priority than directory). If you wanna render foo/index.pug, you have to use explicit path: this.render('foo/index').

For this.render('bar'), because bar.pug doesn't exist and bar is a directory, koa-pug will search for bar/index.pug and try to render it.

For this.render('baz'), because baz is a file, and not end with .pug, koa-pug will throw an ENOENT error.

Migration Notes

2.x

  • this.render becomes a normal function, it does not require yield statement anymore. (Issue #14)

Contributors

Via GitHub