-
Notifications
You must be signed in to change notification settings - Fork 223
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
[PROPOSAL] Build tool to optimise Imager library (so it includes only code actually used) #30
Comments
Regarding #25 and some other, that's true it can become counter productive only for the sake of the filesize and the context. I like your idea of having some features shipped in the core experience and enabling them to build their own flavour by removing/adding other features at build time. Additionally to a grunt task, it would make sense in combination with an updated @kaelig's Imager.js customiser. |
@oncletom sounds good to me |
Although a more complex example, you might find it useful looking at how Alternatively, ensuring that all non-core features are shipped as plugins makes that task of dropping unused features at build-time a great deal more easy. This is the approach taken by the jQuery project and others who found actual build-time parsing to be a less ideal option. |
What do you think of browserify? If we use it to generate UMD module, we can use |
For folks who like to keep everything in the same package manager, it's certainly a means to an end :) On UMD: I think that as long as the final version built for the user doesn't suffer from too much wrapper overhead, that option is appealing and as you mention, would let us create various bundles. |
Agreed with @addyosmani on trying to prevent wrapper'itus if possible :-) |
Looking over the proposals that @oncletom has written up, it seems like it would be a good idea to have some form of Grunt task that the user could use to optimise the API of Imager.
By this I mean, if we look at #25 (triggering events manually), I suggested making sure the default behaviour was the
resize
event and the user could override that behaviour. So if the user decided to do just that, the Imager library would still have a chunk of code that would no longer be needed in production. It would be good if they could run a grunt task which they could specify what API's they have used (or which they have overridden) and then Grunt would clean-up the Imager library code so it only included code actually used.The text was updated successfully, but these errors were encountered: