feat: add support for transforming vw and vh units into calc() expressions using CSS variables.#2377
Conversation
…expressions using CSS variables.
🦋 Changeset detectedLatest commit: e0de618 The changes in this PR will be included in the next version bump. This PR includes changesets to release 9 packages
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
📝 WalkthroughWalkthroughAdds configurable viewport-unit transformations (rpx, vw, vh) across CSS defaults, Rust style-transformer, WASM bindings, and TypeScript worker/main-thread paths; tests and E2E cover the new behavior. Changes introduce TransformerConfig and thread transform flags through encode/decode and inline-style APIs. Changes
Estimated code review effort🎯 4 (Complex) | ⏱️ ~60 minutes Possibly related PRs
Suggested reviewers
Poem
🚥 Pre-merge checks | ✅ 2 | ❌ 1❌ Failed checks (1 warning)
✅ Passed checks (2 passed)
✏️ Tip: You can configure your own custom pre-merge checks in the settings. ✨ Finishing Touches🧪 Generate unit tests (beta)
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. Comment |
Codecov Report❌ Patch coverage is 📢 Thoughts on this report? Let us know! |
Merging this PR will not alter performance
Comparing Footnotes
|
Web Explorer#8419 Bundle Size — 727.67KiB (+0.41%).e0de618(current) vs 36b38eb main#8397(baseline) Bundle metrics
Bundle size by type
Bundle analysis report Branch PupilTong:p/hw/support-rpx-and-v... Project dashboard Generated by RelativeCI Documentation Report issue |
There was a problem hiding this comment.
Actionable comments posted: 1
Caution
Some comments are outside the diff and can’t be posted inline due to platform limitations.
⚠️ Outside diff range comments (3)
packages/web-platform/web-core/tests/element-apis.spec.ts (3)
1375-1391:⚠️ Potential issue | 🟡 MinorMissing
transformVWandtransformVHin SSR test config.The
createServerElementAPIconfig object is missing the newly requiredtransformVWandtransformVHproperties. Based on the changes topackages/web-platform/web-core/ts/server/elementAPIs/createElementAPI.ts(lines 99-100), these are now required fields in the config type.🔧 Proposed fix
const config = { enableCSSSelector: true, defaultOverflowVisible: false, defaultDisplayLinear: true, + transformVW: false, + transformVH: false, };🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core/tests/element-apis.spec.ts` around lines 1375 - 1391, The test's config passed to createServerElementAPI is missing the now-required numeric callbacks transformVW and transformVH; update the config object used in the 'create element infer css id from parent component in SSR' test to include transformVW and transformVH properties (functions returning numbers) so the config shape matches the new createElementAPI expectations and the call to createServerElementAPI compiles.
1461-1465:⚠️ Potential issue | 🟡 MinorMissing
transform_vwandtransform_vhparameters indecode_style_infocall.The
decode_style_infofunction signature was updated to require two additional boolean parameters (transform_vw,transform_vh), but this call site was not updated.🔧 Proposed fix
const encodedStyleInfo = wasmInstance.decode_style_info( encodedRawStyleInfo, undefined, true, + false, + false, );🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core/tests/element-apis.spec.ts` around lines 1461 - 1465, Call to wasmInstance.decode_style_info is missing the two new boolean parameters transform_vw and transform_vh; update the invocation (the encodedStyleInfo assignment) to include those two booleans (e.g., pass false, false or the appropriate test variables) so the call matches the updated signature: decode_style_info(encodedRawStyleInfo, undefined, true, transform_vw, transform_vh).
1413-1428:⚠️ Potential issue | 🟡 MinorMissing
transformVWandtransformVHin second SSR test config.Same issue as the previous SSR test - the config object needs the new required properties.
🔧 Proposed fix
const config = { enableCSSSelector: true, defaultOverflowVisible: false, defaultDisplayLinear: true, + transformVW: false, + transformVH: false, };🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core/tests/element-apis.spec.ts` around lines 1413 - 1428, The test "create element wont infer css id if parent css id is 0 in SSR" passes a config to createServerElementAPI but omits the required transformVW and transformVH properties; add transformVW and transformVH to the config object used in this test (the same properties used in the previous SSR test) so the config matches the expected shape when calling createServerElementAPI.
🧹 Nitpick comments (2)
packages/web-platform/web-core/src/style_transformer/mod.rs (1)
18-18: Narrow visibility unless external consumers are intentionally supported.Line 18 makes
token_transformerpart of the public crate API. Based on current usage, this appears to be internal-only and can be crate-scoped to avoid unnecessary long-term API surface.Proposed change
- pub mod token_transformer; + pub(crate) mod token_transformer; + pub(crate) use token_transformer::TransformerConfig;Based on learnings: CSS processing in
packages/web-platform/web-core/src/{css_tokenizer,style_transformer}/**/*.rsshould stay focused and efficient; keeping API surface minimal helps maintain that boundary.🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core/src/style_transformer/mod.rs` at line 18, The module declaration `pub mod token_transformer` unnecessarily exposes internal APIs; change it to a crate-private module by replacing the `pub mod token_transformer` declaration with a private `mod token_transformer`, then update any external references that relied on the public path (or add a minimal, intentional public wrapper/re-export if external consumers truly need one). Search for uses of `token_transformer::` outside the crate and either adjust call sites to use the internal path (within the crate) or create a small, explicit public facade function/type to re-export only the required symbols rather than the entire module.packages/web-platform/web-core-e2e/tests/reactlynx/basic-vw-vh-unit/index.jsx (1)
6-19: Consider removing the unnecessary fragment wrapper for consistency.The
<>...</>fragment wrapper around the single<view>element is unnecessary since there's only one child. Thebasic-rpx-unit/index.jsxtest doesn't use a fragment wrapper for its single element.♻️ Suggested simplification
function App() { return ( - <> - <view - id='target' - style={{ - height: '50vh', - width: '50vw', - background: 'blue', - }} - /> - </> + <view + id='target' + style={{ + height: '50vh', + width: '50vw', + background: 'blue', + }} + /> ); }🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core-e2e/tests/reactlynx/basic-vw-vh-unit/index.jsx` around lines 6 - 19, Remove the unnecessary JSX fragment in the App component: update the App function (function App) to return the single <view id='target' .../> element directly instead of wrapping it with the fragment (<>...</>), so the component returns the single root element without the fragment for consistency with basic-rpx-unit/index.jsx.
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.
Inline comments:
In
`@packages/web-platform/web-core/src/main_thread/server/main_thread_server_context.rs`:
- Around line 35-37: The changes introduce main-thread-visible style
transformation flags (transform_vw and transform_vh) in the server context, but
there are no corresponding JS-side tests; add cases to element-apis.spec.ts that
cover the updated main-thread style-transformation behavior by exercising the
code paths that read transform_vw and transform_vh (and other modified
transformation logic in the same main-thread module) — create test elements,
apply styles that use vw/vh-based transforms, and assert the computed
styles/layout and any expected transform results to ensure the new flags behave
correctly from the JS side.
---
Outside diff comments:
In `@packages/web-platform/web-core/tests/element-apis.spec.ts`:
- Around line 1375-1391: The test's config passed to createServerElementAPI is
missing the now-required numeric callbacks transformVW and transformVH; update
the config object used in the 'create element infer css id from parent component
in SSR' test to include transformVW and transformVH properties (functions
returning numbers) so the config shape matches the new createElementAPI
expectations and the call to createServerElementAPI compiles.
- Around line 1461-1465: Call to wasmInstance.decode_style_info is missing the
two new boolean parameters transform_vw and transform_vh; update the invocation
(the encodedStyleInfo assignment) to include those two booleans (e.g., pass
false, false or the appropriate test variables) so the call matches the updated
signature: decode_style_info(encodedRawStyleInfo, undefined, true, transform_vw,
transform_vh).
- Around line 1413-1428: The test "create element wont infer css id if parent
css id is 0 in SSR" passes a config to createServerElementAPI but omits the
required transformVW and transformVH properties; add transformVW and transformVH
to the config object used in this test (the same properties used in the previous
SSR test) so the config matches the expected shape when calling
createServerElementAPI.
---
Nitpick comments:
In
`@packages/web-platform/web-core-e2e/tests/reactlynx/basic-vw-vh-unit/index.jsx`:
- Around line 6-19: Remove the unnecessary JSX fragment in the App component:
update the App function (function App) to return the single <view id='target'
.../> element directly instead of wrapping it with the fragment (<>...</>), so
the component returns the single root element without the fragment for
consistency with basic-rpx-unit/index.jsx.
In `@packages/web-platform/web-core/src/style_transformer/mod.rs`:
- Line 18: The module declaration `pub mod token_transformer` unnecessarily
exposes internal APIs; change it to a crate-private module by replacing the `pub
mod token_transformer` declaration with a private `mod token_transformer`, then
update any external references that relied on the public path (or add a minimal,
intentional public wrapper/re-export if external consumers truly need one).
Search for uses of `token_transformer::` outside the crate and either adjust
call sites to use the internal path (within the crate) or create a small,
explicit public facade function/type to re-export only the required symbols
rather than the entire module.
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: 0a45efb0-299e-4fe1-b4be-019f1242d8ba
📒 Files selected for processing (33)
.changeset/transform-rpx.md.changeset/transform-vw-vh-support.mdpackages/web-platform/web-core-e2e/tests/reactlynx.spec.tspackages/web-platform/web-core-e2e/tests/reactlynx/basic-rpx-unit/index.jsxpackages/web-platform/web-core-e2e/tests/reactlynx/basic-vw-vh-unit/index.jsxpackages/web-platform/web-core/binary/client/client.d.tspackages/web-platform/web-core/binary/client/client_bg.wasm.d.tspackages/web-platform/web-core/binary/encode/encode.d.tspackages/web-platform/web-core/binary/encode/encode_bg.wasm.d.tspackages/web-platform/web-core/binary/server/server.d.tspackages/web-platform/web-core/binary/server/server_bg.wasm.d.tspackages/web-platform/web-core/css/index.csspackages/web-platform/web-core/src/main_thread/client/element_apis/style_apis.rspackages/web-platform/web-core/src/main_thread/server/main_thread_server_context.rspackages/web-platform/web-core/src/style_transformer/inline_style.rspackages/web-platform/web-core/src/style_transformer/mod.rspackages/web-platform/web-core/src/style_transformer/token_transformer.rspackages/web-platform/web-core/src/style_transformer/transformer.rspackages/web-platform/web-core/src/template/template_sections/style_info/decoded_style_data.rspackages/web-platform/web-core/src/template/template_sections/style_info/raw_style_info.rspackages/web-platform/web-core/src/template/template_sections/style_info/style_info_decoder.rspackages/web-platform/web-core/tests/element-apis.spec.tspackages/web-platform/web-core/tests/template-manager.spec.tspackages/web-platform/web-core/ts/client/decodeWorker/cssLoader.tspackages/web-platform/web-core/ts/client/decodeWorker/decode.worker.tspackages/web-platform/web-core/ts/client/decodeWorker/types.tspackages/web-platform/web-core/ts/client/mainthread/LynxView.tspackages/web-platform/web-core/ts/client/mainthread/LynxViewInstance.tspackages/web-platform/web-core/ts/client/mainthread/TemplateManager.tspackages/web-platform/web-core/ts/client/mainthread/elementAPIs/createElementAPI.tspackages/web-platform/web-core/ts/server/decode.tspackages/web-platform/web-core/ts/server/deploy.tspackages/web-platform/web-core/ts/server/elementAPIs/createElementAPI.ts
👮 Files not reviewed due to content moderation or server errors (8)
- .changeset/transform-rpx.md
- packages/web-platform/web-core/ts/client/decodeWorker/cssLoader.ts
- .changeset/transform-vw-vh-support.md
- packages/web-platform/web-core/ts/client/mainthread/elementAPIs/createElementAPI.ts
- packages/web-platform/web-core/ts/client/mainthread/TemplateManager.ts
- packages/web-platform/web-core/css/index.css
- packages/web-platform/web-core-e2e/tests/reactlynx.spec.ts
- packages/web-platform/web-core/ts/server/deploy.ts
packages/web-platform/web-core/src/main_thread/server/main_thread_server_context.rs
Show resolved
Hide resolved
There was a problem hiding this comment.
Actionable comments posted: 1
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.
Inline comments:
In `@packages/web-platform/web-core-e2e/tests/reactlynx.spec.ts`:
- Around line 404-408: Update the outdated/misleading comment that describes
container-query math to reflect the actual test setup and expectations: mention
that --vw-unit and --vh-unit are 10px so 50vw/50vh compute to 500px (matching
the assertions in expect(target).toHaveCSS('width','500px') and
expect(target).toHaveCSS('height','500px')), and remove the incorrect
container-query 25px/50px explanation; also remove the unnecessary await on the
synchronous page.locator(...) call (used to assign target) so the locator is
obtained without await.
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: de39a139-7439-45ae-a79b-56b158eda07c
📒 Files selected for processing (3)
packages/web-platform/web-core-e2e/tests/reactlynx.spec.tspackages/web-platform/web-core/binary/client_legacy/client.d.tspackages/web-platform/web-core/binary/client_legacy/client_bg.wasm.d.ts
…e and SSR element APIs, including transformation to `calc()` expressions.
There was a problem hiding this comment.
Actionable comments posted: 1
♻️ Duplicate comments (1)
packages/web-platform/web-core-e2e/tests/reactlynx.spec.ts (1)
407-415:⚠️ Potential issue | 🟠 MajorPost-toggle assertions do not verify the intended behavior.
Line 414 and Line 415 (
not 25px/not 50px) are too weak and may pass even when transform toggling is broken. Assert that the transformed500pxresults are no longer present (or assert explicit expected values after disabling).🔧 Suggested assertion update
- await expect(target).not.toHaveCSS('width', '25px'); - await expect(target).not.toHaveCSS('height', '50px'); + await expect(target).not.toHaveCSS('width', '500px'); + await expect(target).not.toHaveCSS('height', '500px');🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed. In `@packages/web-platform/web-core-e2e/tests/reactlynx.spec.ts` around lines 407 - 415, After disabling transforms via lynxView.evaluate (setting node.transformVW = false and node.transformVH = false followed by node.reload()), replace the weak negative assertions on target.toHaveCSS('width','25px') and ('height','50px') with explicit assertions that verify the transformed 500px values are no longer present (e.g., assert target does not have width/height '500px') or assert the explicit expected dimensions after disabling transforms; update assertions referencing target and toHaveCSS so they validate the intended post-toggle dimensions rather than just "not 25px"/"not 50px".
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.
Inline comments:
In `@packages/web-platform/web-core/tests/element-apis.spec.ts`:
- Around line 439-461: The tests call createElementAPI(...) with
transformVW/transformVH enabled but still assert raw 'vw'/'vh' CSS strings;
update the assertions to expect transformed values (or validate computed style)
instead of raw units. Locate tests using createElementAPI and __SetInlineStyles
(e.g., the test named "__SetInlineStyles with object and vw/vh when enabled" and
similar cases around lines referenced) and change
expect(targetStyle).toBe('width:50vw;height:100vh;') to assert the transformed
result produced when transformVW/transformVH are true (or retrieve computed
styles from the DOM and assert those), and apply the same fix to the other
affected tests that assert 'vw'/'vh'/'rpx' when transforms are enabled.
---
Duplicate comments:
In `@packages/web-platform/web-core-e2e/tests/reactlynx.spec.ts`:
- Around line 407-415: After disabling transforms via lynxView.evaluate (setting
node.transformVW = false and node.transformVH = false followed by
node.reload()), replace the weak negative assertions on
target.toHaveCSS('width','25px') and ('height','50px') with explicit assertions
that verify the transformed 500px values are no longer present (e.g., assert
target does not have width/height '500px') or assert the explicit expected
dimensions after disabling transforms; update assertions referencing target and
toHaveCSS so they validate the intended post-toggle dimensions rather than just
"not 25px"/"not 50px".
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: 9217d863-8e71-484d-a79a-ed128af22d72
📒 Files selected for processing (2)
packages/web-platform/web-core-e2e/tests/reactlynx.spec.tspackages/web-platform/web-core/tests/element-apis.spec.ts
This PR was opened by the [Changesets release](https://github.com/changesets/action) GitHub action. When you're ready to do a release, you can merge this and the packages will be published to npm automatically. If you're not ready to do a release yet, that's fine, whenever you add more changesets to main, this PR will be updated. # Releases ## @lynx-js/rspeedy@0.14.0 ### Minor Changes - feat: add `Minify.mainThreadOptions` and `Minify.backgroundOptions` for thread-specific minifier. ([#2336](#2336)) ### Patch Changes - Bump Rsbuild v1.7.4 with Rspack v1.7.10. ([#2384](#2384)) - Updated dependencies \[]: - @lynx-js/web-rsbuild-server-middleware@0.20.0 ## @lynx-js/lynx-bundle-rslib-config@0.3.0 ### Minor Changes - **BREAKING CHANGE**: ([#2370](#2370)) Simplify the API for external bundle builds by `externalsPresets` and `externalsPresetDefinitions`. ### Patch Changes - Preserve the default external-bundle `output.minify.jsOptions` when users set `output.minify: true` in `defineExternalBundleRslibConfig`, so required minifier options are not lost. ([#2390](#2390)) ## @lynx-js/external-bundle-rsbuild-plugin@0.1.0 ### Minor Changes - **BREAKING CHANGE**: ([#2370](#2370)) Simplify the API for external bundle builds by `externalsPresets` and `externalsPresetDefinitions`. ### Patch Changes - Updated dependencies \[[`7b7a0c6`](7b7a0c6)]: - @lynx-js/externals-loading-webpack-plugin@0.1.0 ## @lynx-js/react-rsbuild-plugin@0.14.0 ### Minor Changes - feat: support `optimizeBundleSize` option to remove unused code for main-thread and background. ([#2336](#2336)) - If `optimizeBundleSize` is `true` or `optimizeBundleSize.background` is `true`, `lynx.registerDataProcessors` calls will be marked as pure for the background thread output. - If `optimizeBundleSize` is `true` or `optimizeBundleSize.mainThread` is `true`, `NativeModules.call` and `lynx.getJSModule` calls will be marked as pure for the main-thread output. ### Patch Changes - refactor: remove `modifyWebpackChain` since Rsbuild 2.0 dropped webpack support ([#2397](#2397)) - Updated dependencies \[[`9193711`](9193711)]: - @lynx-js/template-webpack-plugin@0.10.7 - @lynx-js/css-extract-webpack-plugin@0.7.0 - @lynx-js/react-webpack-plugin@0.8.0 - @lynx-js/react-alias-rsbuild-plugin@0.14.0 - @lynx-js/use-sync-external-store@1.5.0 - @lynx-js/react-refresh-webpack-plugin@0.3.5 ## @lynx-js/web-core@0.20.0 ### Minor Changes - **This is a breaking change** ([#2322](#2322)) ## Architectural Upgrade: `web-core-wasm` replaces `web-core` This release marks a major architectural upgrade for the web platform. The experimental, WASM-powered engine formerly known as `web-core-wasm` has been fully stabilized and merged into the main branch, completely replacing the previous pure JS/TS based `web-core` implementation. This consolidation massively improves execution performance and aligns the API boundaries of the Web platform directly with other native Lynx implementations. ### 🎉 Added Features - **Core API Enhancements**: Successfully exposed and supported `__QuerySelector` and `__InvokeUIMethod` methods. - **Security & CSP Compliance**: Added a `nonce` attribute to the iframe's `srcdoc` script execution, strengthening Content Security Policy (CSP) compliance. - **`<lynx-view>` Parameter Enhancements**: - Added the `browser-config` attribute and property to `<lynx-view>`. Development environments can now supply a `BrowserConfig` object (e.g., configuring `pixelRatio`, `pixelWidth`, `pixelHeight`) allowing the `systemInfo` payload to be dynamically configured at the instance level. ### 🔄 Changed Features - **Legacy JSON Backwards Compatibility**: Delivered comprehensive fixes and optimizations to deeply support legacy JSON output templates: - Added support for lazy loading execution mode (`lazy usage`). - Implemented the correct decoding and handling of `@keyframe` animation rules. - Rectified rule scoping matching including scoped CSS, root selectors, and type selectors. - **Ecosystem Migration**: Updated testing and ecosystem applications (such as `web-explorer` and `shell-project`) to migrate away from obsolete fragmented dependencies. The new WASM architecture seamlessly integrates Element APIs and CSS directly inside the core client module, requiring a much simpler initialization footprint. **Before (Legacy `web-core` + `web-elements`):** ```typescript // Required multiple imports to assemble the environment import "@lynx-js/web-core/client"; import type { LynxViewElement as LynxView } from "@lynx-js/web-core"; // Had to manually import separate elements and their CSS import "@lynx-js/web-elements/index.css"; import "@lynx-js/web-elements/all"; const lynxView = document.createElement("lynx-view") as LynxView; // ... ``` **After (New `web-core` unified architecture):** ```typescript // The new engine natively registers Web Components and injects fundamental CSS import "@lynx-js/web-core/client"; import type { LynxViewElement as LynxView } from "@lynx-js/web-core/client"; const lynxView = document.createElement("lynx-view") as LynxView; // ... ``` _(Applications can now drop `@lynx-js/web-elements` entirely from their `package.json` dependencies)._ - **Dependency & Boot Sequence Improvements**: Re-architected module loading pathways. Promoted `wasm-feature-detect` directly to a core dependency, and hardened the web worker count initialization assertions. - **Initialization Optimizations**: Converted `SERVER_IN_SHADOW_CSS` initialization bounds to use compilation-time constant expressions for better optimization. ### 🗑️ Deleted Features & Structural Deprecations - **`<lynx-view>` Parameter Removals**: - Removed the `thread-strategy` property and attribute. Historically, this permitted consumers to toggle between `'multi-thread'` and `'all-on-ui'` modes depending on how they wanted the background logic to be executed. The WASM-driven architecture enforces a consolidated concurrency model, deprecating this `<lynx-view>` attribute entirely. - Removed the `overrideLynxTagToHTMLTagMap` property/attribute. HTML tag overriding mechanism has been deprecated in the new engine. - Removed the `customTemplateLoader` property handler from `<lynx-view>`. - Removed the `inject-head-links` property and attribute (`injectHeadLinks`), which previously was used to automatically inject `<link rel="stylesheet">` tags from the document head into the `lynx-view` shadow root. - **Fragmented Packages Removal**: The new cohesive WASM architecture native to `@lynx-js/web-core` handles cross-thread communication, worker boundaries, and rendering loops uniformly. Consequently, multiple obsolete packages have been completely removed from the workspace: - `@lynx-js/web-mainthread-apis` - `@lynx-js/web-worker-runtime` - `@lynx-js/web-core-server` - `@lynx-js/web-core-wasm-e2e` (transitioned into standard test suites) - Added support for `rpx` unit ([#2377](#2377)) **This is a breaking change** The following Styles has been added to `web-core` ```css lynx-view { width: 100%; container-name: lynx-view; container-type: inline-size; --rpx-unit: 1cqw; } ``` Check MDN for the details about these styles: - <https://developer.mozilla.org/en-US/docs/Web/CSS/Reference/Properties/container-name> - <https://developer.mozilla.org/en-US/docs/Web/CSS/Reference/Properties/container-type> - <https://developer.mozilla.org/en-US/docs/Web/CSS/Guides/Containment/Container_queries> ### how it works? For the following code ```html <view style="height:1rpx"></view> ``` it will be transformed to ```html <view style="height:calc(1 * var(--rpx-unit))"></view> ``` Therefore you could use any `<length>` value to replace the unit, for example: ```html <lynx-view style="--rpx-unit:1px"></lynx-view> ``` By default, the --rpx-unit value is `1cqw` - Added support for transform `vw` and `vh` unit ([#2377](#2377)) Add `transform-vw` and `transform-vh` attributes and properties on `<lynx-view>`. For the following code ```html <view style="height:1vw"></view> ``` If the `transform-vw` is enabled `<lynx-view transform-vw="true">`, it will be transformed to ```html <view style="height:calc(1 * var(--vw-unit))"></view> ``` Therefore you could use any `<length>` value to replace the unit, for example: ```html <lynx-view style="--vw-unit:1px"></lynx-view> ``` ### Patch Changes - feat(web-core): add `is_bubble` parameter to `common_event_handler` to properly handle non-bubbling events like `window.Event('click', { bubbles: false })`. ([#2399](#2399)) - chore: update readme ([#2380](#2380)) - fix: the output format should be module ([#2388](#2388)) - opt: use opt-level 3 to compile wasm ([#2371](#2371)) - fix(web-core): avoid partial bundle loading and double fetching when fetchBundle is called concurrently for the same url. ([#2386](#2386)) - fix(web-core): fallback to the original export chunk when `processEvalResult` is absent during `queryComponent` execution ([#2399](#2399)) - fix: tokenizing inline style values correctly to support rpx and ppx unit conversion ([#2381](#2381)) This fixes an issue where the `transform_inline_style_key_value_vec` API bypassed the CSS tokenizer, preventing dimension units like `rpx` or `ppx` from being successfully transformed into `calc` strings when specified via inline styles. - feat: add mts lynx.querySelectorAll API ([#2382](#2382)) - fix: mts in lazy component ([#2375](#2375)) - fix: enableJSDataProcessor not work ([#2372](#2372)) - feat: add `ppx` unit support for CSS, transforming to `calc(... * var(--ppx-unit))` directly. ([#2381](#2381)) - Updated dependencies \[]: - @lynx-js/web-worker-rpc@0.20.0 ## @lynx-js/externals-loading-webpack-plugin@0.1.0 ### Minor Changes - **BREAKING CHANGE**: ([#2370](#2370)) Simplify the API for external bundle builds by `externalsPresets` and `externalsPresetDefinitions`. ## @lynx-js/devtool-connector@0.1.1 ### Patch Changes - fix: align GlobalKeys with Android DevToolSettings keys and filter global switch responses ([#2392](#2392)) ## @lynx-js/devtool-mcp-server@0.5.1 ### Patch Changes - Updated dependencies \[[`95fff27`](95fff27)]: - @lynx-js/devtool-connector@0.1.1 ## @lynx-js/react@0.117.1 ### Patch Changes - Update preact version to simplify `setProperty` implementation ([#2367](#2367)) ## @lynx-js/react-umd@0.117.1 ### Patch Changes - Add a new `entry` export to `@lynx-js/react-umd` for reuse by wrapper libraries of `@lynx-js/react`. ([#2370](#2370)) ## create-rspeedy@0.14.0 ### Patch Changes - Add optional Lynx DevTool skill. ([#2421](#2421)) - move Vitest integration to create-rstack extraTools and merge the Vitest templates into a single incremental overlay ([#2408](#2408)) ## @lynx-js/kitten-lynx-test-infra@0.1.2 ### Patch Changes - Updated dependencies \[[`95fff27`](95fff27)]: - @lynx-js/devtool-connector@0.1.1 ## @lynx-js/template-webpack-plugin@0.10.7 ### Patch Changes - use path.posix.format instead of path.format to ensure consistent path separators across platforms ([#2359](#2359)) - Updated dependencies \[[`75960cd`](75960cd), [`518c310`](518c310), [`863469e`](863469e), [`dc18c5c`](dc18c5c), [`7d242f3`](7d242f3), [`62bebcf`](62bebcf), [`75960cd`](75960cd), [`182f568`](182f568), [`1aa051d`](1aa051d), [`6b46f7e`](6b46f7e), [`fcda36a`](fcda36a), [`182f568`](182f568), [`138f727`](138f727), [`138f727`](138f727)]: - @lynx-js/web-core@0.20.0 ## @lynx-js/react-alias-rsbuild-plugin@0.14.0 ## upgrade-rspeedy@0.14.0 ## @lynx-js/web-rsbuild-server-middleware@0.20.0 ## @lynx-js/web-worker-rpc@0.20.0 Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Summary by CodeRabbit
New Features
Style
Tests
Breaking Changes
Checklist