Skip to content
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

Only apply forwardRef for React when props.ref is passed #1172

Open
wants to merge 11 commits into
base: main
Choose a base branch
from
8 changes: 4 additions & 4 deletions docs/hooks.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,13 +52,13 @@ export default function MyComponent() {

<details>

In React you may need to wrap your component with `forwardRef` to provide direct access to an element (`input` for example). You can do this by using using a `prop` value as the `ref`
In React you may need to wrap your component with `forwardRef` to pass a `ref` property to a component. You can do this by naming one of your Mitosis `prop`s `ref`

_Mitosis input_

```typescript
export default function MyInput(props) {
return <input ref={props.inputRef} />;
return <input ref={props.ref} />;
}
```

Expand All @@ -67,8 +67,8 @@ _Mitosis output_
```typescript
import { forwardRef } from 'react';

export default forwardRef(function MyInput(props, inputRef) {
return <input ref={inputRef} />;
export default forwardRef(function MyInput(props, ref) {
return <input ref={ref} />;
});
```

Expand Down
52 changes: 50 additions & 2 deletions packages/core/src/__tests__/__snapshots__/alpine.test.ts.snap
Original file line number Diff line number Diff line change
Expand Up @@ -1442,7 +1442,7 @@ exports[`Alpine.js > jsx > Javascript Test > basicForwardRef 1`] = `
<div x-data=\\"myBasicForwardRefComponent()\\">
<input
class=\\"input\\"
x-ref=\\"inputRef\\"
x-ref=\\"ref\\"
x-bind:value=\\"name\\"
x-on:change=\\"name = $event.target.value\\"
/>
Expand Down Expand Up @@ -1709,6 +1709,30 @@ exports[`Alpine.js > jsx > Javascript Test > defaultValsWithTypes 1`] = `
"
`;

exports[`Alpine.js > jsx > Javascript Test > dontForwardRef 1`] = `
"<style>
.input {
color: red;
}
</style>
<div x-data=\\"dontForwardRefComponent()\\">
<input
class=\\"input\\"
x-ref=\\"inputRef\\"
x-bind:value=\\"name\\"
x-on:change=\\"name = $event.target.value\\"
/>
</div>
<script>
document.addEventListener(\\"alpine:init\\", () => {
Alpine.data(\\"dontForwardRefComponent\\", () => ({
name: \\"PatrickJS\\",
}));
});
</script>
"
`;

exports[`Alpine.js > jsx > Javascript Test > expressionState 1`] = `
"<div x-data=\\"myComponent()\\"><span x-html=\\"refToUse\\"></span></div>
<script>
Expand Down Expand Up @@ -3990,7 +4014,7 @@ exports[`Alpine.js > jsx > Typescript Test > basicForwardRef 1`] = `
<div x-data=\\"myBasicForwardRefComponent()\\">
<input
class=\\"input\\"
x-ref=\\"inputRef\\"
x-ref=\\"ref\\"
x-bind:value=\\"name\\"
x-on:change=\\"name = $event.target.value\\"
/>
Expand Down Expand Up @@ -4257,6 +4281,30 @@ exports[`Alpine.js > jsx > Typescript Test > defaultValsWithTypes 1`] = `
"
`;

exports[`Alpine.js > jsx > Typescript Test > dontForwardRef 1`] = `
"<style>
.input {
color: red;
}
</style>
<div x-data=\\"dontForwardRefComponent()\\">
<input
class=\\"input\\"
x-ref=\\"inputRef\\"
x-bind:value=\\"name\\"
x-on:change=\\"name = $event.target.value\\"
/>
</div>
<script>
document.addEventListener(\\"alpine:init\\", () => {
Alpine.data(\\"dontForwardRefComponent\\", () => ({
name: \\"PatrickJS\\",
}));
});
</script>
"
`;

exports[`Alpine.js > jsx > Typescript Test > expressionState 1`] = `
"<div x-data=\\"myComponent()\\"><span x-html=\\"refToUse\\"></span></div>
<script>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2624,6 +2624,44 @@ export class ComponentWithTypesModule {}
"
`;

exports[`Angular with Preserve Imports and File Extensions > jsx > Javascript Test > dontForwardRef 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";

import { Component } from \\"@angular/core\\";

@Component({
selector: \\"dont-forward-ref-component, DontForwardRefComponent\\",
template: \`
<div>
<input
class=\\"input\\"
[attr.value]=\\"name\\"
(input)=\\"name = $event.target.value\\"
/>
</div>
\`,
styles: [
\`
.input {
color: red;
}
\`,
],
})
export class DontForwardRefComponent {
name = \\"PatrickJS\\";
}

@NgModule({
declarations: [DontForwardRefComponent],
imports: [CommonModule],
exports: [DontForwardRefComponent],
})
export class DontForwardRefComponentModule {}
"
`;

exports[`Angular with Preserve Imports and File Extensions > jsx > Javascript Test > expressionState 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";
Expand Down Expand Up @@ -6452,7 +6490,7 @@ import { Component } from \\"@angular/core\\";

export interface Props {
showInput: boolean;
inputRef: HTMLInputElement;
ref: HTMLInputElement;
}

@Component({
Expand Down Expand Up @@ -7004,6 +7042,49 @@ export class ComponentWithTypesModule {}
"
`;

exports[`Angular with Preserve Imports and File Extensions > jsx > Typescript Test > dontForwardRef 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";

import { Component } from \\"@angular/core\\";

export interface Props {
showInput: boolean;
inputRef: HTMLInputElement;
}

@Component({
selector: \\"dont-forward-ref-component, DontForwardRefComponent\\",
template: \`
<div>
<input
class=\\"input\\"
[attr.value]=\\"name\\"
(input)=\\"name = $event.target.value\\"
/>
</div>
\`,
styles: [
\`
.input {
color: red;
}
\`,
],
})
export class DontForwardRefComponent {
name = \\"PatrickJS\\";
}

@NgModule({
declarations: [DontForwardRefComponent],
imports: [CommonModule],
exports: [DontForwardRefComponent],
})
export class DontForwardRefComponentModule {}
"
`;

exports[`Angular with Preserve Imports and File Extensions > jsx > Typescript Test > expressionState 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2678,6 +2678,45 @@ export class ComponentWithTypesModule {}
"
`;

exports[`Angular with Import Mapper Tests > jsx > Javascript Test > dontForwardRef 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";

import { Component } from \\"@angular/core\\";

@Component({
selector: \\"dont-forward-ref-component, DontForwardRefComponent\\",
template: \`
<div>
<input
class=\\"input\\"
[attr.value]=\\"name\\"
(input)=\\"name = $event.target.value\\"
/>
</div>
\`,
styles: [
\`
.input {
color: red;
}
\`,
],
})
export class DontForwardRefComponent {
name = \\"PatrickJS\\";
}

@NgModule({
declarations: [DontForwardRefComponent],
imports: [CommonModule],
exports: [DontForwardRefComponent],
bootstrap: [SomeOtherComponent],
})
export class DontForwardRefComponentModule {}
"
`;

exports[`Angular with Import Mapper Tests > jsx > Javascript Test > expressionState 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";
Expand Down Expand Up @@ -6585,7 +6624,7 @@ import { Component } from \\"@angular/core\\";

export interface Props {
showInput: boolean;
inputRef: HTMLInputElement;
ref: HTMLInputElement;
}

@Component({
Expand Down Expand Up @@ -7151,6 +7190,50 @@ export class ComponentWithTypesModule {}
"
`;

exports[`Angular with Import Mapper Tests > jsx > Typescript Test > dontForwardRef 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";

import { Component } from \\"@angular/core\\";

export interface Props {
showInput: boolean;
inputRef: HTMLInputElement;
}

@Component({
selector: \\"dont-forward-ref-component, DontForwardRefComponent\\",
template: \`
<div>
<input
class=\\"input\\"
[attr.value]=\\"name\\"
(input)=\\"name = $event.target.value\\"
/>
</div>
\`,
styles: [
\`
.input {
color: red;
}
\`,
],
})
export class DontForwardRefComponent {
name = \\"PatrickJS\\";
}

@NgModule({
declarations: [DontForwardRefComponent],
imports: [CommonModule],
exports: [DontForwardRefComponent],
bootstrap: [SomeOtherComponent],
})
export class DontForwardRefComponentModule {}
"
`;

exports[`Angular with Import Mapper Tests > jsx > Typescript Test > expressionState 1`] = `
"import { NgModule } from \\"@angular/core\\";
import { CommonModule } from \\"@angular/common\\";
Expand Down
Loading