- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 365
feat: ouput bundled file in esm #2766
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
base: main
Are you sure you want to change the base?
Conversation
| WalkthroughA new Rollup build type called "bundled" was introduced, allowing all dependencies to be included in a single ES module output. The  Changes
 Sequence Diagram(s)sequenceDiagram
    participant Dev as Developer
    participant NPM as npm
    participant Rollup as Rollup
    participant Config as rollup.config.js
    Dev->>NPM: Run "npm run b:bundled"
    NPM->>Rollup: Execute with BUILD_TYPE=BUNDLED, NODE_ENV=release
    Rollup->>Config: Load configuration
    Config->>Config: Generate bundled build (all dependencies included)
    Config->>Rollup: Return bundled build config
    Rollup->>NPM: Output bundled ES module(s)
    NPM->>Dev: Bundled build artifacts generated
Poem
 ✨ Finishing Touches
 Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. 🪧 TipsChatThere are 3 ways to chat with CodeRabbit: 
 SupportNeed help? Create a ticket on our support page for assistance with any issues or questions. Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
 Other keywords and placeholders
 CodeRabbit Configuration File ( | 
| Codecov ReportAll modified and coverable lines are covered by tests ✅ 
 Additional details and impacted files@@           Coverage Diff           @@
##             main    #2766   +/-   ##
=======================================
  Coverage   79.24%   79.24%           
=======================================
  Files         844      844           
  Lines       90062    90062           
  Branches     8922     8926    +4     
=======================================
+ Hits        71367    71371    +4     
+ Misses      18556    18552    -4     
  Partials      139      139           
 Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
 | 
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.
Actionable comments posted: 0
🧹 Nitpick comments (1)
rollup.config.js (1)
164-167: Fix prettier formatting issues.The minify plugin configuration has formatting issues that need to be addressed.
- bundledPlugins.push(minify({ - sourceMap: true, - module: true // Indicate this is an ES module - })); + bundledPlugins.push( + minify({ + sourceMap: true, + module: true // Indicate this is an ES module + }) + );
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
- package.json(1 hunks)
- rollup.config.js(3 hunks)
🧰 Additional context used
🪛 ESLint
rollup.config.js
[error] 164-164: Insert ⏎··········
(prettier/prettier)
[error] 165-165: Insert ··
(prettier/prettier)
[error] 166-166: Insert ··
(prettier/prettier)
[error] 167-167: Replace }) with ··})⏎········
(prettier/prettier)
⏰ Context from checks skipped due to timeout of 90000ms. You can increase the timeout in your CodeRabbit configuration to a maximum of 15 minutes (900000ms). (2)
- GitHub Check: e2e (22.x)
- GitHub Check: codecov
🔇 Additional comments (5)
package.json (1)
19-19: LGTM! Script follows established patterns.The new
b:bundledscript is consistent with existing build scripts and properly configures the environment variables for the bundled build type.rollup.config.js (4)
147-182: LGTM! Bundled method implementation is well-structured.The
bundledmethod correctly implements ES module bundling with:
- Proper handling of compression with GLSL plugin replacement
- Empty external array to bundle all dependencies
- Correct ES module format output
- Proper sourcemap configuration
The logic mirrors the UMD method's compression handling, ensuring consistency.
199-201: LGTM! Build type integration is clean.The BUNDLED case properly integrates with the existing build system and correctly calls the getBundled function.
230-241: LGTM! getBundled function correctly limits scope.The function properly:
- Filters to only the
@galacean/enginepackage- Generates both compressed and uncompressed bundles
- Returns an empty array if the package isn't found
This targeted approach makes sense for bundled builds since they're typically only needed for the main engine package.
243-243: LGTM! getAll function updated correctly.The inclusion of bundled builds in the getAll function maintains consistency with the existing pattern.
Summary by CodeRabbit
New Features
Chores