Cyril N.
Cyril N.

Reputation: 39879

Render a Play!Framework2 javascript as template?

I'd like to return a .js file from a template in Play!Framework 2.

Here's how I did that :

In my views folder, I created a template file :

initials.scala.js

Containinig something like :

{
    'data': @Model.find.findList()
}

And then, in my controller :

public static Result initials() {
    return ok(views.js.initials.render());
}

This is pretty straighforward for me, but I get this error :

error: package views.js does not exist

What I did wrong?

If I rename js to txt (in the filename and the package call in the controller), everything works fine. But if I change it to js, I get an error.

Upvotes: 2

Views: 1806

Answers (3)

Sebastien Lorber
Sebastien Lorber

Reputation: 92150

You can have a scala.js file but you don't call it with views.js.initials.render() but instead js.initials.render()

At least with Scala it works with Play 2.2

Upvotes: 0

lloyd-wire
lloyd-wire

Reputation: 1

This is possible by placing a route to the particular asset in your routes definition.

ie. GET /assets/javascripts/initials.js controllers..initials()

Upvotes: 0

biesior
biesior

Reputation: 55798

You did nothing wrong, Play allows you tu use only .html, .xml or .txt extensions for views, so you need to use one of them.

From technical point of view it doesn't matter which one you'll use, anyway you need to return it from controller as JavaScript, ie with:

public static Result initials() {
    return ok(views.html.initials.render()).as("application/javascript");
}

Upvotes: 3

Related Questions