-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
feat(build system): Added step to build process that creates index.js in... #35
Conversation
… in the root folder and exports all the main classes for CommonJS support Change-Id: I53e0bcf483f6e3d46e9d9a28a4881fad7b6be13c
Since index.js is generated code, would you please add it to .gitignore? |
Change-Id: Ife5365fa334b72c682a7da9666df2487e800083e
Sorry for the delay, I missed the update. Thanks for adding this! |
feat(build system): Added step to build process that creates index.js in...
No worries thanks! Any idea when these latest changes will be published to NPM? |
With our next release version, 1.3.0, which I'm currently expecting by the end of the month. Oh, and one more thing I forgot to ask you to add to the pull request before I merged it. Can you please add yourself to CONTRIBUTORS and AUTHORS? |
Ok cool thanks! I've submitted a separate PR for the CONTRIBUTORS and AUTHORS update. #37 |
@palmerj3 For some reason I'm having a hard time finding out exactly where it's failing but from what I can tell it seems like there might be a problem when it hits FakeEventTarget and tries to create shaka.util.MultiMap. shaka seems to be undefined at this point. Do you have any insight here? Or at the very least, could you explain how you are using it? This might give me a better idea of what I have to do to get it working how I want. |
@sanbornhnewyyz I think instead of us supporting all possible async dependency resolution solutions you could utilize webpack or something like this within your project which would allow you to utilize CommonJS, RequireJS, etc dependencies interchangeably. Sounds similar to what you've already done but perhaps take a look at: For me the way I'm using it is: var shaka = require('shaka-player').shaka; var player = new shaka.player.Player(myVideoDomNode); |
@sanbornhnewyyz I spoke too soon... so I was able to get it working but I'm not sure it would be wise to include in the main build... @joeyparrish would like your thoughts. It's not ideal because it's tying the build process to specific implementation details (e.g. shaka.player, shaka.polyfill, etc). But it works... perhaps it's useful to you. If you add this to build.sh: In this case "index2.js" will define all the AMD stuff needed so you can do something like this:
|
@joeyparrish @sanbornhnewyyz I created this - let me know your thoughts. #55 |
@palmerj3 maybe I spoke too soon. At least for requireJS purposes, your commonJS build works fine if you wrap the whole thing with:
I tried doing this with your example above and it playsback fine. But when I try to require this module in our actual project I run into these undefined errors when I try to playback content. So it looks like something is not playing nice with our project I agree with not supporting all module flavours though for the big ones you could add a flag that let's you set which module type you want. |
I wouldn't mind supporting both commonJS and requireJS by default, however I'd prefer it greatly if we could combine all of this into one wrapper. It cuts down compilation time, which makes a big difference for us trying to iterate rapidly on new features. Let's continue this discussion on #55. |
... the root folder and exports all the main classes for CommonJS support
Change-Id: I53e0bcf483f6e3d46e9d9a28a4881fad7b6be13c