Expansion Panel Simple Example
src / Demo.tsx
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104import React, { ReactElement } from "react";
import {
ExpansionList,
ExpansionPanel,
usePanels,
} from "@react-md/expansion-panel";
import { TextField } from "@react-md/form";
import { Grid } from "@react-md/utils";
export default function Demo(): ReactElement {
const [panels, onKeyDown] = usePanels({
idPrefix: "simple-panels",
count: 3,
defaultExpandedIndex: 0,
});
const [panel1Props, panel2Props, panel3Props] = panels;
return (
<ExpansionList onKeyDown={onKeyDown}>
<ExpansionPanel
{...panel1Props}
header="Personal Information"
disablePadding
>
<Grid columns={1} clone>
<TextField
id="person-name"
name="name"
label="Name *"
required
placeholder="John Doe"
/>
<TextField
id="person-email"
name="email"
type="email"
label="Email *"
required
placeholder="some.person@email.com"
/>
<TextField id="person-phone" name="phone" type="tel" label="Phone" />
<TextField
id="person-extension"
name="extension"
label="Extension"
maxLength={4}
placeholder="XXXX"
/>
<TextField
id="person-country"
name="country"
label="Country"
placeholder="XX"
maxLength={2}
/>
<TextField id="person-city" name="city" label="City/Provice" />
</Grid>
</ExpansionPanel>
<ExpansionPanel
{...panel2Props}
header="Billing Information"
disablePadding
>
<Grid columns={1}>
<TextField id="person-address-1" name="address1" label="Address 1" />
<TextField id="person-address-2" name="address2" label="Address 2" />
<TextField id="person-address-city" name="city" label="City" />
<TextField id="person-address-state" name="state" label="State" />
<TextField id="person-address-zip" name="zip" label="Zip Code" />
</Grid>
</ExpansionPanel>
<ExpansionPanel {...panel3Props} header="Billing Address" disablePadding>
<Grid columns={1}>
<TextField
id="person-shipping-address-1"
name="address1"
label="Address 1"
/>
<TextField
id="person-shipping-address-2"
name="address2"
label="Address 2"
/>
<TextField
id="person-shipping-address-city"
name="city"
label="City"
/>
<TextField
id="person-shipping-address-state"
name="state"
label="State"
/>
<TextField
id="person-shipping-address-zip"
name="zip"
label="Zip Code"
/>
</Grid>
</ExpansionPanel>
</ExpansionList>
);
}