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

template-loader

v0.2.0

Published

Load templates from file paths, globs or objects, and cache them as normalized objects.

Downloads

6

Readme

template-loader NPM version

Load templates from file paths, globs or objects, and cache them as normalized objects.

Install

Install with npm:

npm i template-loader --save-dev

Usage

var Loader = require('template-loader');
var templates = new Loader();

API

Loader

Create a new instance of Loader, optionally passing default options.

Example:

var Loader = require('template-loader');
var templates = new Loader();
  • options {Object}: Default options for front-matter and template naming.

Options cache

Template cache

.option

Set or get an option.

loader.option('a', true)
loader.option('a')
// => true
  • key {String}
  • value {*}
  • return {*}

Parse files and extract front matter.

  • str {String}: String to parse.
  • options {Object}: Options to pass to [gray-matter].

Set templates on the cache.

  • name {String}: Template name
  • str {String}: String to parse.
  • options {Object}: loader options

Get a template from the cache.

  • key {String}: The name of the template to get.

Normalize and flatten locals and data objects.

  • obj {Object}: The object to normalize.
  • return {Object}

Resolve, load, and parse all files based on type.

  • pattern {*}: Array, object, function or string.
  • options {Object}: loader options.
  • return {Array} Array of file objects.

Resolve files paths and require them in, calling .load() for futher processing.

  • pattern {String}: Glob patterns or file paths.
  • options {Object}: loader options.
  • return {Object}

Normalize a template object.

  • obj {Object}: The object to normalize.
  • options {Object}: Locals or loader options.

Load multiple template objects.

  • objects {Object}: Template objects.
  • options {Object}: loader options.

Call load for each item in the array.

  • patterns {Object}: Glob patterns or array of filepaths.
  • options {Object}: Additional options to pass
  • return {Array} a list of files as Vinyl objects

Call the function and pass the results to load for futher processing.

  • fn {Function}: Function to call.
  • locals {Object}: Locals or loader options.
  • return {*}

Resolve modules by name and require them. name can be a module name, filepath or glob pattern.

  • name {String}: npm module name, file path or glob pattern to resolve
  • options {Object}: Options to pass to [resolve-dep].

Call the function and pass the results to load for futher processing.

  • fn {Function}: Function to call.
  • locals {Object}: Locals or loader options.
  • return {*}

Call the function and pass the results to load for futher processing.

  • fn {Function}: Function to call.
  • locals {Object}: Locals or loader options.
  • return {*}

Export Loader

.set

templates.set(object, [locals]);

.setFile

Params:

  • filepath
  • locals
templates.setFile(glob, [locals]);

.load

templates.load([template], [locals]);

Params:

  • template: {String|Array|Object}
  • locals: {Object}
  • return: {Object} Returns an object with data, content, original and locals properties.

template formats

Object

String

Array

Examples

templates.load('a/b/*.tmpl');
templates.load(['a/b*.tmpl', 'c/d*.tmpl']);
templates.load(['a/b*.tmpl', 'c/d*.tmpl'], {a: 'b'});
templates.load({a: {data: {}, content: ''}});
templates.load({a: {data: {}, content: ''}}, {a: 'b'});

Author

Jon Schlinkert

License

Copyright (c) 2014 Jon Schlinkert, contributors.
Released under the MIT license


This file was generated by verb-cli on August 12, 2014.