UNPKG

grommet

Version:

focus on the essential experience

171 lines (162 loc) 4.84 kB
import React from 'react'; import { storiesOf } from '@storybook/react'; import { Box, Button, CheckBox, Grommet, Form, FormField, MaskedInput, RadioButtonGroup, RangeInput, Select, TextArea, TextInput } from 'grommet'; import { grommet } from 'grommet/themes'; var Example = function Example() { var _React$useState = React.useState(''), name = _React$useState[0], setName = _React$useState[1]; var _React$useState2 = React.useState(''), email = _React$useState2[0], setEmail = _React$useState2[1]; var _React$useState3 = React.useState(false), subscribe = _React$useState3[0], setSubscribe = _React$useState3[1]; var _React$useState4 = React.useState(''), ampm = _React$useState4[0], setAmpm = _React$useState4[1]; var _React$useState5 = React.useState(''), size = _React$useState5[0], setSize = _React$useState5[1]; var _React$useState6 = React.useState(''), comments = _React$useState6[0], setComments = _React$useState6[1]; var _React$useState7 = React.useState(''), age = _React$useState7[0], setAge = _React$useState7[1]; React.useEffect(function () { setName('initial'); setEmail('initial@my.com'); setSubscribe(true); setAmpm('evening'); setSize('large'); setComments('initial'); setAge(60); }, []); return /*#__PURE__*/React.createElement(Grommet, { full: true, theme: grommet }, /*#__PURE__*/React.createElement(Box, { fill: true, align: "center", justify: "center" }, /*#__PURE__*/React.createElement(Box, { width: "medium" }, /*#__PURE__*/React.createElement(Form, { onChange: function onChange(value) { return console.log('Change', value); }, onReset: function onReset() { setName(''); setEmail(''); setSubscribe(false); setAmpm(''); setSize(''); setComments(''); setAge(''); }, onSubmit: function onSubmit(event) { return console.log('Submit', event.value, event.touched); } }, /*#__PURE__*/React.createElement(FormField, { label: "Name", name: "name" }, /*#__PURE__*/React.createElement(TextInput, { name: "name", value: name, onChange: function onChange(event) { return setName(event.target.value); } })), /*#__PURE__*/React.createElement(FormField, { label: "Email", name: "email", required: true }, /*#__PURE__*/React.createElement(MaskedInput, { name: "email", mask: [{ regexp: /^[\w\-_.]+$/, placeholder: 'example' }, { fixed: '@' }, { regexp: /^[\w]+$/, placeholder: 'my' }, { fixed: '.' }, { regexp: /^[\w]+$/, placeholder: 'com' }], value: email, onChange: function onChange(event) { return setEmail(event.target.value); } })), /*#__PURE__*/React.createElement(FormField, { name: "subscribe" }, /*#__PURE__*/React.createElement(CheckBox, { name: "subscribe", label: "Subscribe?", checked: subscribe, onChange: function onChange(event) { return setSubscribe(event.target.checked); } })), /*#__PURE__*/React.createElement(FormField, { name: "ampm" }, /*#__PURE__*/React.createElement(RadioButtonGroup, { name: "ampm", options: ['morning', 'evening'], value: ampm, onChange: function onChange(event) { return setAmpm(event.target.value); } })), /*#__PURE__*/React.createElement(FormField, { label: "Size", name: "size" }, /*#__PURE__*/React.createElement(Select, { name: "size", options: ['small', 'medium', 'large'], value: size, onChange: function onChange(event) { return setSize(event.option); } })), /*#__PURE__*/React.createElement(FormField, { label: "Comments", name: "comments" }, /*#__PURE__*/React.createElement(TextArea, { name: "comments", value: comments, onChange: function onChange(event) { return setComments(event.target.value); } })), /*#__PURE__*/React.createElement(FormField, { label: "Age", name: "age", pad: true }, /*#__PURE__*/React.createElement(RangeInput, { name: "age", min: 15, max: 75, value: age, onChange: function onChange(event) { return setAge(event.target.value); } })), /*#__PURE__*/React.createElement(Box, { direction: "row", justify: "between", margin: { top: 'medium' } }, /*#__PURE__*/React.createElement(Button, { label: "Cancel" }), /*#__PURE__*/React.createElement(Button, { type: "reset", label: "Reset" }), /*#__PURE__*/React.createElement(Button, { type: "submit", label: "Update", primary: true })))))); }; storiesOf('Form', module).add('Controlled Input lazy', function () { return /*#__PURE__*/React.createElement(Example, null); });