-
Notifications
You must be signed in to change notification settings - Fork 5.2k
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
Haml-Coffee smart package #138
Conversation
Just trying this out using HAML['filename'], getting an error: Uncaught ReferenceError: HAML is not defined |
Hmm, are you sure your file extension is .hamlc? The only reason I can think of the HAML object not being defined is if meteor never saw a .hamlc file. |
Yep. |
Can you post your .meteor/packages? This relies on the haml-coffee-meteor package. My installation process was as follows: install meteor (I'm assuming to /usr/local/meteor, which is the default on OS X) Regarding the haml-coffee-meteor npm package, I wish I had a better way of including it, but all the smart package dependencies are bundled up in a file that's hosted on the meteor devs' server. I would suggest the current way of smart packaging is far from ideal. If the install process isn't your issue, I'll try to figure out what else could be it. |
I did exactly the same process. Hmm. Thanks a lot for helping. I guess if you run a meteor app on heroku (for example) you can simply ship the meteor version with it that has the required npm packages. |
Oh wait, actually I did another thing: I copied your haml-coffee package to my original meteor installation, to /usr/local/meteor/packages. So I did not install meteor from your git repo. Maybe I missed something? |
Copying haml-coffee to /usr/local/meteor/packages should work fine too. So 'meteor add haml-coffee' worked fine? |
So, presuming you have foo.hamlc in your app directory, .meteor/local/build/static/ should contain foo.hamlc.js. Does it? |
Yes, I could do meteor add haml-coffee fine. Yes, my myfile.hamlc.js is in the app dir. |
Can you show me a small working example app i could test out? |
Here's a skeleton app: https://gist.github.com/2876037 |
Your example works fine for me. My code is somewhat different and uses coffeescript:
Maybe there is the issue? Works fine with html templates though. |
Yep, as soon as i try to do the code from my previous comment in your testapp, i get the same error as in my app: Uncaught TypeError: Cannot read property 'my_template' of undefined |
I've used this extensively with coffeescript without issue. You should note that your current error suggests meteor is no longer having issues finding HAML, but rather it looks as if it's not finding 'myfile.hamlc'. So something has changed. Moreover, "HAML['myfile'].my_template.myvariable = ->", doesn't make sense to me. HAML['myfile'] should be a function which you call, passing an object with your desired locals. Look more closely at my example. I suggest you dig in a bit - try translating my example to coffeescript and then work from there. |
The error is coming from your example now which i changed. HAML['myfile'].my_template.myvariable is the default way templates are accessed in meteor. They use it in their screencast. I simply replaced Template.xyz.abc -> with HAML['myfile'].xyz.abc is that not the way to go? I think ideally Template should just work with your haml package too, would be more convenient... See the screencast, the first screen. They use Template.xxx.yyy: http://meteor.com/screencast |
Here is a very basic example that works fine with html, but not with haml: testhaml.hamlc
testhaml.coffee
It gives me the "HAML is not defined error". As soon as I rename the haml file to somethingelse.hamlc it does actually find HAML['somethingelse'], but not the template. I then get: "Cannot set property 'my_var' of undefined " |
This is not how the package works. You seem to be conflating HAML with handlebars. Handlebars uses {{}} syntax to evaluate locals passed to the context, whereas HAML uses #{} or =. Regarding meteor's way of passing locals to Handlebars templates, I found no need to replicate that. Adding partial support (or %template support, as you have it) was well beyond my needs and looked like a lot of work. Currently, you can render a partial by doing !=HAML.my_partial({foo: 'bar'}). I simply followed the lead of the original haml-coffee package. Feel free to make any of your own modifications that you would like. |
Ah, that clears things up! Sorry, this was obviously a misunderstanding then. I was assuming I get full haml support with your package, and handlebars stuff as well. So that I would have a full replacement for html. Maybe it's because I'm coming from a rails background, where you can swap erb with haml. But yes, thinking about it, not sure how handlebars could be combined with haml. Thanks for helping anyway. ;-) |
So what's meteor's stance on including this in meteor's smart packages? I'm hoping it's 👍! |
@huetsch It would be nice to have capture to string support for chunks. For example: = Meteor.ui.chunk ->
%h1= Session.get('title')
%ul
- renderElement = (e)->
%li= e.name
- renderEmpty = ->
%li No elements found!
= Meteor.ui.listChunk Elements.find({}), renderElement, renderEmpty The example above wouldn't work because the render* functions don't return strings. |
You can add npm packages to the dev bundle. If a Meteor smart package depends on a particular npm package, then that npm package should be added to the generate-dev-bundle.sh script: https://github.com/meteor/meteor/blob/master/admin/generate-dev-bundle.sh However, we prefer if all the code for a package goes into the Meteor smart package if possible, rather than creating an accompanying npm package like "haml-coffee-meteor". Packaging issues aside, just a heads up that Spark changes the underlying API that template engines will use to render. See this thread for more details: https://groups.google.com/forum/?fromgroups#!topic/meteor-core/p2wV-anQMjI%5B1-25%5D HAML is a big project. The meteor-core mailing list is a good place to discuss architecture and coordinate with Spark work. |
feat(rule): add rule scope-dom-lookups
I've added a smart package to be able to render .hamlc files via https://github.com/9elements/haml-coffee. I had to ever-so-slightly tweak their npm package into my own version, called 'haml-coffee-meteor', to get it to work. Templates generated by .hamlc files are currently available via a global HAML object. So calling HAML['filename'] when you have a file named filename.hamlc in your app will give you a function that you can call to render.
Please let me know what else I might need to do to get the package merged.