Form Elements

This page contains the usual elements that you will need when building a form. When they are combined with the form grid, found here, you can build responsive forms.

Make sure that you are following accessibility best practices when you are building your forms.

Checkbox

<div class="dk-checkbox-group">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-cb1"
        />
        <label
            class="dk-checkbox-label"
            for="dk-cb1">
            One
        </label>
    </div>
    <div class="dk-checkbox-group">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-cb2"
        />
        <label
            class="dk-checkbox-label"
            for="dk-cb2">
            Two
        </label>
    </div>
    <div class="dk-checkbox-group">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-cb3"
        />
        <label
            class="dk-checkbox-label"
            for="dk-cb3">
            Three
        </label>
    </div>
    <div class="dk-checkbox-group">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-cb4"
        />
        <label
            class="dk-checkbox-label"
            for="dk-cb4">
            Four
        </label>
    </div>

Usage

  • Create a wrapping div with the CLASS of dk-checkbox-group
  • Adding CLASS of dk-checkbox on the Input, immediately followed by a LABEL element will then add the corresponding styles to create our checkboxes. - Also add the input type of checkbox to set the element(s) to be a checkboxes. - To connect both the Input with the Label first give the Input an 'ID', second on Label add 'FOR'. You will then give them the same name in each declaration.

Always use unique IDs as you can only have one per page.

Toggle Checkbox

A useful element for when you need to show whether something is toggled on or off. Used very much like a checkbox but visually conveys a slightly different meaning. Toggles are available in a larger size by adding the dk-checkbox--toggle-lg class name to each checkbox input.

<div>
        <input
            type="checkbox"
            class="dk-checkbox--toggle"
            id="dk-toggle-cb-1"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-toggle-cb-1">
            Toggle One
        </label>
        <input
            type="checkbox"
            class="dk-checkbox--toggle"
            id="dk-toggle-cb-2"
        />
        <label
            class="dk-checkbox-label"
            for="dk-toggle-cb-2">
            Toggle Two
        </label>
    </div>
    <br />
    <div>
        <input
            type="checkbox"
            class="dk-checkbox--toggle dk-checkbox--toggle-lg"
            id="dk-toggle-cb-3"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-toggle-cb-3">
            Toggle One
        </label>
        <input
            type="checkbox"
            class="dk-checkbox--toggle dk-checkbox--toggle-lg"
            id="dk-toggle-cb-4"
        />
        <label
            class="dk-checkbox-label"
            for="dk-toggle-cb-4">
            Toggle Two
        </label>
    </div>

Button Checkbox

<div class="dk-checkbox--button">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-button-cb-3"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-button-cb-3">
            Button One
        </label>
    </div>
    <div class="dk-checkbox--button">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-button-cb-4"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-button-cb-4">
            Button Two
        </label>
    </div>
    <br />
    <br />
    <div class="dk-checkbox--button">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-button-cb-5"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-button-cb-5">
            <span class="icon-floppy"></span>{' '}
            Button One
        </label>
    </div>
    <div class="dk-checkbox--button">
        <input
            type="checkbox"
            class="dk-checkbox"
            id="dk-button-cb-6"
        />
        <label
            class="mr-1 dk-checkbox-label"
            for="dk-button-cb-6">
            <span class="icon-file-pdf"></span>{' '}
            Button Two
        </label>
    </div>

Radio Buttons

<div class="dk-radio-group">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rb1"
        />
        <label
            class="dk-radio-label"
            for="dk-rb1">
            One
        </label>
    </div>
    <div class="dk-radio-group">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rb2"
        />
        <label
            class="dk-radio-label"
            for="dk-rb2">
            Two
        </label>
    </div>
    <div class="dk-radio-group">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rb3"
        />
        <label
            class="dk-radio-label"
            for="dk-rb3">
            Three
        </label>
    </div>
    <div class="dk-radio-group">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rb4"
        />
        <label
            class="dk-radio-label"
            for="dk-rb4">
            Four
        </label>
    </div>

Usage

Note: To see checked state style of the radio button simply click on the button.

  1. Adding CLASS of dk-radio on the Input, immediately followed by a Label element will then add the corresponding styles to create our radio buttons.
  2. Also add the input type of radio to set the element(s) to be a radio button.
  3. To connect both the Input with the Label first give the Input an ID, second on Label add FOR. You will then give them the same name in each declaration.Always use unique IDs as you can only have one per page.

Button Radio

<div class="dk-radio--button">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rbbutton1"
        />
        <label
            class="mr-1 dk-radio-label"
            for="dk-rbbutton1">
            One
        </label>
    </div>
    <div class="dk-radio--button">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rbbutton2"
        />
        <label
            class="mr-1 dk-radio-label"
            for="dk-rbbutton2">
            Two
        </label>
    </div>
    <br />
    <br />
    <div class="dk-radio--button">
        <input
            type="radio"
            name="radio"
            class="dk-radio"
            id="dk-rbbutton3"
        />
        <label
            class="mr-1 dk-radio-label"
            for="dk-rbbutton3">
            Line One
            <br />
            Line Two
            <br />
            Line Three
        </label>
    </div>

Form Input

Form Input Field:

  1. Make a wrapping div with the CLASS of dk-input-group.
  2. Inside of the wrapping div place the LABEL element with the CLASS of dk-input-label. Set the for attribute to the same value as the ID on the input.
  3. Add CLASS dk-input to the INPUT element to style the input correctly
  4. Every input needs a unique id and a label with a for attribute that matches the id of the input it belongs to. If you are grouping multiple inputs together, every input still needs a label. If the label doesn't need to be present visually you can add the sr-only class to hide it visually but still make it available to screen readers.
<div class="dk-input-group">
        <label
            for="labelInput"
            class="dk-input-label">
            Input Label
        </label>
        <input
            type="text"
            id="labelInput"
            placeholder="Placeholder Text"
            class="dk-input"
        />
        <label
            for="labelInput"
            class="dk-input-label">
            Number Only Input Label
        </label>
        <input
            type="number"
            pattern="[0-9]*"
            min="0"
            id="labelInput"
            placeholder="123456"
            autoComplete="false"
            class="dk-input"
        />
        <label
            for="labelInput"
            class="dk-input-label">
            Email Address Input Label
        </label>
        <input
            type="email"
            min="0"
            id="labelInput"
            placeholder="email@address.com"
            class="dk-input"
        />
        <label
            for="labelInput"
            class="dk-input-label">
            Phone Number Input Label
        </label>
        <input
            type="tel"
            pattern="[0-9]{3}-[0-9]{3}-[0-9]{4}"
            min="0"
            id="labelInput"
            placeholder="123-456-7890"
            class="dk-input"
        />
        <label
            for="labelInput"
            class="dk-input-label">
            Date Input Label
        </label>
        <input
            type="date"
            id="labelInput"
            placeholder="Placeholder Text"
            class="dk-input"
        />
    </div>

Form Input Field with Helper Text:

  1. Setup the input like normal
  2. Add a SMALL element right above the input where you want the helper text to be displayed.
  3. Add the CLASS of dk-input-helper to that SMALL element.
<div class="dk-input-group">
        <label
            for="labelInput"
            class="dk-input-label">
            Input Label
        </label>
        <small class="dk-input-helper">
            This is an example of some
            instructional text
        </small>
        <input
            type="text"
            id="labelInput"
            class="dk-input"
        />
    </div>

Error Field:

  1. To make an INPUT show an error state and show an error message add the CLASS dk-error to the dk-input-group or to an individual input in the group.

  2. To give the user feedback on why the form has an error use a SMALL element with the CLASS dk-error-message.

  3. Inside this element place your error message. By default this field is not displayed unless the dk-input-group has dk-error. If you want to have an error message that is always visible you can use the dk-error-message__visible CLASS. That class will make the message always visible and it's up to you to hide and show it.

<div class="dk-input-group">
        <label
            for="errorInput"
            class="dk-input-label">
            Field with error
        </label>
        <input
            type="text"
            id="errorInput"
            class="dk-input dk-input--error"
        />
        <small class="dk-input__error-feedback">
            User Name or Password is incorrect
        </small>
    </div>

Disabled Field:

  • Add the disabled attribute to the INPUT field
<div class="dk-input-group">
        <label
            for="disabledInput"
            class="dk-input-label">
            Disabled field
        </label>
        <input
            type="text"
            id="disabledInput"
            placeholder="Disabled Field"
            disabled=""
            class="dk-input"
        />
    </div>