Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Template Destination Path and File Extension #47

Open
ghost opened this issue May 15, 2014 · 5 comments
Open

Template Destination Path and File Extension #47

ghost opened this issue May 15, 2014 · 5 comments

Comments

@ghost
Copy link

ghost commented May 15, 2014

I am working on using grunt with a backbone/cordova (phonegap)...

It would be nice to have a "dest_path" and "include_ext" options so you could set the destination folder of the template and whether or not to include the extension of the file name in the template name.

Example:

jst: {
     compile: {
         options: {
             prettify: true
         },
         files: {
             "www/javascripts/templates.js": ["www/javascripts/templates/*.jst.ejs"]
         }
     }
}

The end result is that each template has "www/javascripts/templates/" before each templat name:

 this["JST"]["www/javascripts/templates/modal_message.jst.ejs"] = function...

The new option would like look like:

jst: {
     compile: {
         options: {
             dest_path: "templates",
             include_ext: false,
             prettify: true
         },
         files: {
             "www/javascripts/templates.js": ["www/javascripts/templates/*.jst.ejs"]
         }
     }
}

and the end results would be:

this["JST"]["templates/modal_message"] = function...

So in backbone I can refer to the templates as such:

 this.template = JST["templates/modal_message"];

Clear as mud?

BTW, thanks for the work on this. It is going to save me a bunch of time. 👍

@ghost ghost changed the title Template Destination Path Template Destination Path and File Extension May 15, 2014
@traviswimer
Copy link

I find this inconvenient as well. I'm surprised no one else has commented on this.

@traviswimer
Copy link

In case anyone is looking for a quick workaround for this, I decided to just use this plugin to fix the paths:
https://github.com/erickrdch/grunt-string-replace

So you just run the string-replace plugin after the JST plugin. Going with @jcochran 's example, you just do something like this:

'string-replace': {
    jst: {
        files: {
            'www/javascripts/templates.js': 'www/javascripts/templates.js'
        },
        options: {
            replacements: [{
                pattern: /www\/javascripts\/templates/ig,
                replacement: 'templates'
            }]
        }
    }
},

@ghost
Copy link
Author

ghost commented Sep 15, 2014

Yes, I went with something very similar.

Sent from my iPhone

On Sep 15, 2014, at 12:06 PM, "Travis Wimer" <[email protected]mailto:[email protected]> wrote:

In case anyone is looking for a quick workaround for this, I decided to just use this plugin to fix the paths:
https://github.com/erickrdch/grunt-string-replace

So you just run the string-replace plugin after the JST plugin. Going with @jcochranhttps://github.com/jcochran 's example, you just do something like this:

'string-replace': {
jst: {
files: {
'www/javascripts/templates.js': 'www/javascripts/templates.js'
},
options: {
replacements: [{
pattern: /www/javascripts/templates/ig,
replacement: 'templates'
}]
}
}
},


Reply to this email directly or view it on GitHubhttps://github.com//issues/47#issuecomment-55622788.

@rogierborst
Copy link

You don't need a separate plugin for this. There is an option built right into this one, called processName.
So you can do

jst: {
    compile: {
        options: {
            processName: function(thatHugeFilepath){
                return thatHugeFilepath.replace('/www/javascripts/templates/', 'templates');
            }
        }
    }
}

Of course, you can just as easily use any other string function to transform your template names.

@traviswimer
Copy link

Thanks for explaining. That works perfectly.

I actually saw that option in the README, but it I found it rather unclear. The description mentions the JST namespace, so I thought it was basically an alternative to the namespace option that allowed you to use a function.

Rereading it now, it does make sense, but the wording could probably be clearer.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants