@trend/textfield v0.4.0
TextField
React component that allows users to input and select text.
Installation
## Has peer dependency with react and react-dom
npm install react react-dom
npm install @trend/textfieldBasic Usage
With a module bundler like webpack, use as you would anything else:
TextField
Default TextField
// Using ES6 modules.
import React from 'react';
import TextField from '@trend/textfield';
function DefaultTextField() {
  return <div>
    <TextField>
      <TextField.Input />
      <TextField.Label children="Label" />
    </TextField>
  </div>;
}
function WithHelperText() {
  return <div>
    <TextField helperText="Here is some helper text.">
      <TextField.Input />
      <TextField.Label children="Label" />
    </TextField>
  </div>;
}
// Interact with label and input like normal react components.
function RandomTextField() {
  return <div>
    <TextField>
      <TextField.Input required onChange={() => {}} minLength={3} />
      <TextField.Label children="Label" />
    </TextField>
  </div>;
}Methods
Input (static)
Add an input to a textfield. Should only ever be a single input per textfield. Inherits state from parent textfield through the React Context API. Interact with the input like any other React component.
import TextField from '@trend/textfield';
function MyInput() {
  return <div>
    <TextField><TextField.Input {...props} /></TextField>
  </div>;
}Label (static)
Add a label to a textfield. Should only ever be a single label per textfield. Inherits state from parent textfield through the React Context API. Interact with the label like any other React component.
import TextField from '@trend/textfield';
function MyInput() {
  return <div>
    <TextField><TextField.Label {...props} /></TextField>
  </div>;
}Props API
BeginningIcon
function| optional
Add a beginning icon to the textfield.
import { Data } from '@trend/icon';
import TextField from '@trend/TextField';
function BeginningIconTextField() {
  return <div>
    <TextField BeginningIcon={Data || () => <Data {...props} />}>
      //...
    </TextField>
  </div>;
}EndingIcon
function| optional
Add a ending icon to the textfield.
import { Edit } from '@trend/icon';
import TextField from '@trend/TextField';
function EndingIconTextField() {
  return <div>
    <TextField EndingIcon={Edit || () => <Edit {...props} />}>
      //...
    </TextField>
  </div>;
}cssClasses
object| Optional. See below example for defaults and object shape.
Customize the classnames for component.
// Default cssClasses prop.
// NOTE: customizing the RIM and/or TEXTAREA classnames will still be matched
// to the rim or textarea value that is matched when using the variant prop.
const cssClass = {
  ROOT: 'tc-TextField',
  BEGINNING_ICON: 'tc-TextField--beginningIcon',
  ENDING_ICON: 'tc-TextField--endingIcon',
  RIM: 'tc-TextField--rim',
  STRETCH: 'tc-TextField--stretch',
  TEXTAREA: 'tc-TextField--textarea',
  HELPER: 'tc-TextField-helper',
  ICON: 'tc-TextField-icon',
  INPUT: 'tc-TextField-input',
  LABEL: 'tc-TextField-label',
  ACTIVE: 'is-active',
  DISABLED: 'is-disabled',
  FOCUSED: 'is-focused',
  INVALID: 'is-invalid'
}disabled
boolean| Optional,false
Render the textfield in a disabled state.
helperText
string| Optional
Add text below form control. NOTE, the element rendered is a sibling to the actual textfield component and not a direct child.
id
string| Optional. Defaults totc-textfield-<uniqueID>
Syncs input.id with the label.for attributes.
stretch
bool| Optional.
Apply the stretch variant to a TextField.
validators
array| Optional.
Add custom validations or edit default validation messages.  The TextField component currenlty applies reasonable defaults for: required, minLength, and pattern attributes on the TextField.Input.
// Validators Array format.
const validators = [
  'require|minLength|pattern',
  {
    // One of `required`, `minLength`, `pattern`, or `invalid`
    type: 'required',
    message: 'Custom message.'
  },
  function (/* input element */target) {
    // Some custom logic.
    // Return object if error.
    return {
      type, // One of `required`, `minLength`, `pattern`, or `invalid`
      message //...
    }
    // Or no error return a falsy value.
    return //undefined, null, false
  }
];
// Use default validations.
function DefaultValidations() {
  return <div>
    <TextField>
      <TextField.Input required minLength={3} pattern={...} />
    </TextField>
  </div>;
}
function CustomMessages() {
   return <div>
    <TextField validators=[{
      type: 'required',
      message: 'Please provide a value for this Textield.'
    }]>
      <TextField.Input required minLength={3} pattern={...} />
    </TextField>
  </div>;
}variant
string| Optional. Needs to be one of: rim or textarea.
Adjust the appearance of a TextField.