DEV Community

Cover image for Using React Hook Form v6+ with Ionic React Components - Update

Using React Hook Form v6+ with Ionic React Components - Update

Aaron K Saunders on July 17, 2020

🔆Click Here for Ionic Framework ReactJS and VueJS Tips/Tutorials?🔆 This is a quick post showing quickly how to make latest version of Re...
Collapse
 
aaronksaunders profile image
Aaron K Saunders • • Edited

Saw this issue on Stackoverflow, stackoverflow.com/questions/630772...

here is a workaround

You can just add the interface...

export interface CheckboxChangeEventDetail {
  value: any;
  checked: boolean;
}
Enter fullscreen mode Exit fullscreen mode

and then set the code

<IonItem>
  <Controller
    render={({ onChange, onBlur }) => (
      <IonCheckbox
        onIonChange={(e: CustomEvent<CheckboxChangeEventDetail>) => {
          onChange(e?.detail.checked);
          console.log(e);
        }}
        onIonBlur={onBlur}
      />
    )}
    control={control}
    defaultValue={false}
    name="saveInfo"
    rules={{
      required: false,
    }}
  />
</IonItem>
Enter fullscreen mode Exit fullscreen mode
Collapse
 
curiouswebs profile image
curious-webs •

Tried using interface for email field But still getting "Property 'onChange' does not exist on type"
in here
render={({ onChange, onBlur, value }) => (

Collapse
 
wendyperalta profile image
Wendy •

Thank you for updating this. How would you go about testing this component? I have a simple Ionic Text Input component wrapped in a Controller just like the example above.

<Controller
      control={control}
      name="emailInput"
      rules={{ required: true }}
      render={({ value, onChange, onBlur }) => (
        <IonInput
          type="text"
          value={value}
          data-testid="input-email"
          onIonChange={onChange}
          onBlur={onBlur}
        />
      )}
    />

I've tried to use the example from this article:

import { ionFireEvent as fireIonEvent } from "@ionic/react-test-utils";
const emailInput = await findByTestId("input-email");
fireIonEvent.ionChange(emailInput, "test@email.com");

I've also tried this (since ion input components have a detail property that specifies the value of the input:

import { fireEvent } from "@testing-library/react";
fireEvent.change(emailInput, { target: { detail: { value: {"test@email.com" }}});

None of these methods get me what I need which is the value for these inputs being updated in the test. Any ideas?

Collapse
 
patelrikin profile image
Rikin Patel •

You can probably do debug() from testing library after each fired event and see if the thing changed at all to investigate

Collapse
 
wendyperalta profile image
Wendy •

I did do that, but it didn't change.

Thread Thread
 
aaronksaunders profile image
Aaron K Saunders •

put the id on the Controller and fire a onChange event don't use the ionic events

Thread Thread
 
wendyperalta profile image
Wendy •

When I moved the data-testid='input-email' to the Controller component wrapper, now I get an error in the test:
TestingLibraryElementError: Unable to find an element by: [data-testid="input-email"]
I'm assuming because it is a custom component.

Thread Thread
 
aaronksaunders profile image
Aaron K Saunders •

can you put a simple project together on stackblitz?

Thread Thread
 
uxtx_tim profile image
Tim Proffitt •

Im curious what came of this - having the same issues :(

Collapse
 
gvilomar profile image
gvilomar •

Hi @aaronksaunders , I'm having an issue with Ionic 7, react-hook-form, and modals. If I submit the page and it finds errors, the error messages do not disappear even though I fix the error. Also, it can continue. I've watched several of your videos and read through many of your post but I cannot see what is wrong. See my code below. Let me know if you have any other suggestions I can try. Thanks in advance!

stackblitz code

Collapse
 
gvilomar profile image
gvilomar •

Sorry @aaronksaunders, the link above was for the app and not the code. Here's the code link:

code

Collapse
 
clementvp profile image
Van Peuter Clément •

Hello, How do you reset the form ? Or how do you set values to the form (with a proper render of the form ?)

Collapse
 
aaronksaunders profile image
Aaron K Saunders •

you reset the form using the reset method from the hook... you set the form using the default values, it is funny that you asked because i was working on a blog post about that!!

Collapse
 
aaronksaunders profile image
Aaron K Saunders •
Collapse
 
patelrikin profile image
Rikin Patel •

Thanks for this quick update