Skip to content

Commit

Permalink
feat(transformer): implement react-jsx-self
Browse files Browse the repository at this point in the history
  • Loading branch information
Boshen committed Apr 12, 2024
1 parent ba2121f commit ea29570
Show file tree
Hide file tree
Showing 6 changed files with 50 additions and 1 deletion.
6 changes: 6 additions & 0 deletions crates/oxc_ast/src/ast/jsx.rs
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,12 @@ pub struct JSXIdentifier<'a> {
pub name: Atom<'a>,
}

impl<'a> JSXIdentifier<'a> {
pub fn new(span: Span, name: Atom<'a>) -> Self {
Self { span, name }
}
}

// 1.4 JSX Children

/// JSX Child
Expand Down
5 changes: 5 additions & 0 deletions crates/oxc_transformer/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -122,4 +122,9 @@ impl<'a> VisitMut<'a> for Transformer<'a> {
self.x1_react.transform_export_default_declaration(decl);
walk_mut::walk_export_default_declaration_mut(self, decl);
}

fn visit_jsx_opening_element(&mut self, elem: &mut JSXOpeningElement<'a>) {
self.x1_react.transform_jsx_opening_element(elem);
walk_mut::walk_jsx_opening_element_mut(self, elem);
}
}
29 changes: 29 additions & 0 deletions crates/oxc_transformer/src/react/jsx_self/mod.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
use std::rc::Rc;

use oxc_ast::ast::*;
use oxc_span::SPAN;

use crate::context::Ctx;

/// [plugin-transform-react-jsx-self](https://babeljs.io/docs/babel-plugin-transform-react-jsx-self)
Expand All @@ -19,4 +22,30 @@ impl<'a> ReactJsxSelf<'a> {
pub fn new(ctx: &Ctx<'a>) -> Self {
Self { ctx: Rc::clone(ctx) }
}

pub fn transform_jsx_opening_element(&self, elem: &mut JSXOpeningElement<'a>) {
self.add_self_this_attribute(elem);
}
}

impl<'a> ReactJsxSelf<'a> {
/// `<div __self={this} />`
/// ^^^^^^^^^^^^^
fn add_self_this_attribute(&self, elem: &mut JSXOpeningElement<'a>) {
let name = {
let name = self.ctx.ast.new_atom("__self");
JSXAttributeName::Identifier(JSXIdentifier::new(SPAN, name))
};
let value = {
let this_expr = self.ctx.ast.this_expression(SPAN);
let jsx_expr = JSXExpression::Expression(this_expr);
let container = self.ctx.ast.jsx_expression_container(SPAN, jsx_expr);
JSXAttributeValue::ExpressionContainer(container)
};
let attribute = {
let attribute = self.ctx.ast.jsx_attribute(SPAN, name, Some(value));
JSXAttributeItem::Attribute(attribute)
};
elem.attributes.push(attribute);
}
}
4 changes: 4 additions & 0 deletions crates/oxc_transformer/src/react/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -76,4 +76,8 @@ impl<'a> React<'a> {
) {
self.display_name.transform_export_default_declaration(decl);
}

pub fn transform_jsx_opening_element(&mut self, elem: &mut JSXOpeningElement<'a>) {
self.jsx_self.transform_jsx_opening_element(elem);
}
}
6 changes: 5 additions & 1 deletion tasks/transform_conformance/babel.snap.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
Passed: 75/174
Passed: 76/177

# All Passed:

Expand Down Expand Up @@ -107,3 +107,7 @@ Passed: 75/174
# babel-plugin-transform-react-display-name (15/16)
* display-name/nested/input.js

# babel-plugin-transform-react-jsx-self (1/3)
* react-source/arrow-function/input.js
* react-source/disable-with-super/input.js

1 change: 1 addition & 0 deletions tasks/transform_conformance/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ const CASES: &[&str] = &[
// React
// "babel-plugin-transform-react-jsx",
"babel-plugin-transform-react-display-name",
"babel-plugin-transform-react-jsx-self",
// // Proposal
// "babel-plugin-proposal-decorators",
];
Expand Down

0 comments on commit ea29570

Please sign in to comment.