-
Notifications
You must be signed in to change notification settings - Fork 32
Conversation
Thanks for the PR! Any suggestions for testing? I think I need to spin up a test app in Fastboot. How difficult would it be to add https://github.com/kaliber5/ember-fastboot-addon-tests ? |
So actually, this PR will conflict with #78 . I suggest that one gets merged first then I'll update again against master to be Fastboot friendly. Since Fastboot 1.0.0 support breaks older fastboot packages and change to npm usage, we'll probably need some upgrade notice in the README. So this will be a good time for a version bump and for upgrades to check both at the same time. I can also take a look at adding Fastboot tests. Any thoughts on adding tests automatic test checks for PR's? |
What is the status of this? We really need this addon to work with fastboot! Thanks! |
@gandalfar how are things looking for you? Can you resolve the conflicts and take a stab at writing the Fastboot tests? I think Travis CI has been setup to run on PRs. Is that right, @acoustep? |
Yes, Travis CI has been set up for PRs. |
I'll give it a look this week. |
I've pushed 'merge' that uses new npm resolve pattern. If somebody else can also test this branch, it would be great. Next step for me is to figure out how to write fastboot tests (and to fix ember-beta failing test) |
It turns out that these tests are already failing in |
I've merged current master changes and tests now pass. |
@gandalfar Do you happen to have a test project you're using to test these changes? I'd like to check it out. :) |
index.js
Outdated
files: this.jsFilesToInclude | ||
}); | ||
|
||
foundationTree = esTranspiler(foundationTree, { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we can do away with the plugins and manually importing the broccoli-babel-transpiler
by leveraging ember-cli-babel
with something like (replacing line 42-64):
var babelAddon = this.addons.find(addon => addon.name === 'ember-cli-babel');
if (isGTE6_3_0) {
foundationPath = path.resolve(require.resolve('foundation-sites'), '../../../js'); // go deeper
}
foundationTree = new Funnel(foundationPath, {
destDir: 'foundation-sites',
files: this.jsFilesToInclude
});
foundationTree = babelAddon.transpileTree(foundationTree);
This would mean we won't need to have babel-core
, babel-plugin-transform-*
, babel-register
, and broccoli-babel-transpiler
.
index.js
Outdated
return new mergeTrees([vendorTree, foundationTree]); | ||
}, | ||
|
||
|
||
included: function included(app) { | ||
this._super.included(app); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think you also need to set the this.app
somewhere in case the addon is used within an addon.
@gandalfar Sorry, I somehow committed/pushed changes to your branch. I don't even know how that is possible. |
@GCheung55 no problem. I'll just leave the commit in, since I assume it will be part of For testing this out, I think the best way would be to ensure that dummy app in this addon provides foundation's kitchen sink CSS + some components and this would allow us to also easily ensure Fastboot compatibility. |
I've added |
@gandalfar I dug into the issue where Basically
I think we need to create a file that loads those modules - probably dynamically using something like @acoustep What are your thoughts here? Should we get that part addressed before merging this? |
That sounds fine to me (using |
@acoustep @gandalfar Sorry for the delay guys. I've finally made time to switch to using Rollup to load Please check things out and try out the fastboot-ness. |
While trying this out on my own project, I came across a breaking change that's been introduced.
This basically removes the dependency on |
Happy New Year! @acoustep @gandalfar ping! When this get's merged, consider publishing a minor or major version. |
I'm actually not sure what needs to be done in this PR to be ready for merge. @GCheung55 do you have open issues list? |
@gandalfar I don't have any open issues. I just pinged you to review what I've done and if things make sense. I did introduce a breaking change that requires If things look good to you, I think all that we're waiting for is @acoustep. If he says it's good I can just merge and he'll need to publish to npm. |
I was following your changes and they look good to me. I also think that going with explicit imports for globals is better and feels in line with what's happening in Ember ecosystem in general. |
Hey @acoustep any chance to get this reviewed and merged? Thanks. |
…nodeModulesPath Packages updated: ember-cli, ember-source, ember-cli-sass, ember-cli-version-checker
I've pushed a bump of deps that fixes Ember 2.18's depreciation:
This PR might not be the best place for additional changes, but I'm not sure what to fork from, so I'm continuing development in it for now. |
Merged and publishing to npm shortly 🙂 |
Moves tree processing from
included()
intotreeForVendor
so that we can usefastbootTransform
on JS funnel (which guards for Fastboot).All the JS processing logic now happens in
treeForVendor
because it builds a modified verision of JS files that are only later imported inincluded
.I've also replaced
babel
withbroccoli-babel-transpiler
so that it's part oftreeForVendor
funnel pipeline.Looking at this code, it seems that supporting installations via npm shouldn't be too much extra work and it would allow the plugin to drop bower.json as dependancy. But that's for another PR and ticket.
Needs a review and more testing as right now I've tested it mainly with Foundation 6.3.x and ember-cli: 2.13.2 (and Ember 2.13.x).
It also extra note that it's incompatible with versions of Fastboot before 1.0.0.
Ref #74 #75