Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
grunt-template-export
Advanced tools
Note this task is a grunt wrapper for template-export.
A grunt multi-task, in MVC terms, a controller that acts as a near-transparent liason between a model and a view (referred to as a translator within this project). It enables the simple, yet highly custom exporting of templates (or other content) to a given destination.
The template-export task has four primary concerns:
The magic is in the fact that the model fetching and translation are both handeled by user-defined modules that simply need to expose a pre-determined API. As long as the modules follow this API, they can do anything they need to under-the-hood in order to generate the proper output. Specifying an implementation for either of these modules is optional.
npm install --save lzilioli/grunt-template-export
var handlebars = require( 'handlebars' );
grunt.initConfig({
template-export: {
options: {
/* NOTE: The opts argument passed to model.getModel, model.init,
* translator.init, and translator.translate will contain all of
* the options passed in except for the following 3
* reserved keys (explained below):
* [ sourceFiles | translator | model ] */
sourceFiles: {
/* This should be an object containing key/value
* pairs, where each value specifies a set of files
* associated with the given key.
*
* Each set of values will be expanded into a flat list
* of source files. You can specify the source files
* the same way you would specify files to a grunt
* read-only task.
*
* The resulting object will then be passed to
* model.init and translator.init. Those functions
* may do with the object what they please.
*
* This might be used to pass a list of markdown files
* to your model, and a set of templates to your
* translator for proper rendering. It's all up
* to you. */
templates: { src: [ 'templates/**/*.tmpl' ] },
posts: { src: [ 'blog/posts/**/*.md' ] }
},
/* Below are the default implementations for a model and a
* translator. If you don't provide either in the task options,
* the default implementation will be used. Additionally,
* if the model or translator that you provide omits one
* of the expected functions, the task will fall back on the
* implementations provided below for that function only. */
model: {
init: _.noop,
getModel: function() { return { }; }
},
translator: {
init: _.noop,
translate: _.identity
// _.identity is a fn that returns it's first arg
}
},
/****** EXAMPLES ************************************/
// Export the homepage, specified by templates/index.tmpl to
// export/blog.html, registering all partials in sourceFiles.templates
// as handlebars partials
homepage: {
src: [ 'src/templates/index.tmpl' ],
dest: [ 'export/blog/index.html' ],
options: {
/* A default handlebars translator is provided. This
* translator will automatically register all of the
* templates specified in options.templates that pass
* the isPartial test with handlebars with the name
* returned by getPartialName.
*
* During translation, your template will be run through
* handlebars with the designated partials registered.
*
* See the below "Extending the Default Translator" section
* for an example on inheriting some of the default handlebars
* translator's functionality. */
translator: require('template-export').translators.handlebars(
/* You must pass handlebars as your first argument
* (see v0.0.2 commit for v0.0.2 for an explanation) */
handlebars,
/* The second argument is optional. It allows you to
* specify functions to determine if a template
* should be considered a partial (isPartial), and if so,
* what name to register with handlebars (getPartialName)
* If either is omitted, the default implementations
* (shown below) will be used. */
{
getPartialName: function( partialPath ) {
// The relative path of the partial from sourceDir, without the .tmpl extension
return partialPath.replace( '.tmpl', '' );
},
isPartial: function( filePath ) {
// Something is considered a partial if the filename begins with `_`
return path.basename( filePath )[ 0 ] === '_';
}
}
)
}
},
// Render all of the templates in templates/**/*.tmpl out to
// their corresponding location in build/static with the
// .html extension, using a static model specified with JSON
all: {
expand: true,
cwd: 'templates',
src: [ '**/*.tmpl' ],
dest: 'build/static',
options: {
translator: require( 'template-export' ).translators.handlebars(handlebars),
model: {
getModel: function(){ grunt.file.readJSON( 'model.json' ) }
}
}
},
// Move all of the files in templates/**/*.tmpl out to
// their corresponding location in build/templates
// (since this falls back on the default implementations for
// the model and the translator, the templates pass-through the
// task without being altered).
move: {
src: 'templates/**/*.tmpl',
dest: 'build/templates'
}
}
});
options.sourceFiles
-- see the Configuring the Task section above for an explanation of this argument
options.translator
options.translator.init
function( sourceFiles, opts )
options.translator.translate
function( templateContents, model, opts, templatePath )
options.model.getModel()
options.model
options.model.init
function( sourceFiles, opts )
options.model.getModel
function( opts, templatePath, templateContents )
options.templates
FAQs
grunt-template-export =====================
The npm package grunt-template-export receives a total of 1 weekly downloads. As such, grunt-template-export popularity was classified as not popular.
We found that grunt-template-export demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.