katoikia-app/web-ui/web-react/src/templates/FormLayoutDemo.js

131 lines
5.7 KiB
JavaScript
Raw Normal View History

2022-07-06 04:15:11 +00:00
import React, { useState } from 'react';
import { InputText } from 'primereact/inputtext';
import { Button } from 'primereact/button';
import { InputTextarea } from 'primereact/inputtextarea';
import { Dropdown } from 'primereact/dropdown';
const FormLayoutDemo = () => {
const [dropdownItem, setDropdownItem] = useState(null);
const dropdownItems = [
{ name: 'Option 1', code: 'Option 1' },
{ name: 'Option 2', code: 'Option 2' },
{ name: 'Option 3', code: 'Option 3' }
];
return (
<div className="grid">
<div className="col-12 md:col-6">
<div className="card p-fluid">
<h5>Vertical</h5>
<div className="field">
<label htmlFor="name1">Name</label>
<InputText id="name1" type="text" />
</div>
<div className="field">
<label htmlFor="email1">Email</label>
<InputText id="email1" type="text" />
</div>
<div className="field">
<label htmlFor="age1">Age</label>
<InputText id="age1" type="text" />
</div>
</div>
<div className="card p-fluid">
<h5>Vertical Grid</h5>
<div className="formgrid grid">
<div className="field col">
<label htmlFor="name2">Name</label>
<InputText id="name2" type="text" />
</div>
<div className="field col">
<label htmlFor="email2">Email</label>
<InputText id="email2" type="text" />
</div>
</div>
</div>
</div>
<div className="col-12 md:col-6">
<div className="card p-fluid">
<h5>Horizontal</h5>
<div className="field grid">
<label htmlFor="name3" className="col-12 mb-2 md:col-2 md:mb-0">Name</label>
<div className="col-12 md:col-10">
<InputText id="name3" type="text" />
</div>
</div>
<div className="field grid">
<label htmlFor="email3" className="col-12 mb-2 md:col-2 md:mb-0">Email</label>
<div className="col-12 md:col-10">
<InputText id="email3" type="text" />
</div>
</div>
</div>
<div className="card">
<h5>Inline</h5>
<div className="formgroup-inline">
<div className="field">
<label htmlFor="firstname1" className="p-sr-only">Firstname</label>
<InputText id="firstname1" type="text" placeholder="Firstname" />
</div>
<div className="field">
<label htmlFor="lastname1" className="p-sr-only">Lastname</label>
<InputText id="lastname1" type="text" placeholder="Lastname" />
</div>
<Button label="Submit"></Button>
</div>
</div>
<div className="card">
<h5>Help Text</h5>
<div className="field p-fluid">
<label htmlFor="username">Username</label>
<InputText id="username" type="text" />
<small>Enter your username to reset your password.</small>
</div>
</div>
</div>
<div className="col-12">
<div className="card">
<h5>Advanced</h5>
<div className="p-fluid formgrid grid">
<div className="field col-12 md:col-6">
<label htmlFor="firstname2">Firstname</label>
<InputText id="firstname2" type="text" />
</div>
<div className="field col-12 md:col-6">
<label htmlFor="lastname2">Lastname</label>
<InputText id="lastname2" type="text" />
</div>
<div className="field col-12">
<label htmlFor="address">Address</label>
<InputTextarea id="address" rows="4" />
</div>
<div className="field col-12 md:col-6">
<label htmlFor="city">City</label>
<InputText id="city" type="text" />
</div>
<div className="field col-12 md:col-3">
<label htmlFor="state">State</label>
<Dropdown id="state" value={dropdownItem} onChange={(e) => setDropdownItem(e.value)} options={dropdownItems} optionLabel="name" placeholder="Select One"></Dropdown>
</div>
<div className="field col-12 md:col-3">
<label htmlFor="zip">Zip</label>
<InputText id="zip" type="text" />
</div>
</div>
</div>
</div>
</div>
)
}
const comparisonFn = function (prevProps, nextProps) {
return prevProps.location.pathname === nextProps.location.pathname;
};
export default React.memo(FormLayoutDemo, comparisonFn);