UIkit
In this example, we will prepare a typical form on UIkit:
html
<form>
<fieldset class="uk-fieldset">
<legend class="uk-legend">Legend</legend>
<div class="uk-margin">
<label class="uk-form-label" for="name">Name</label>
<div class="uk-form-controls">
<input class="uk-input" id="name" name="name" type="text">
</div>
</div>
<div class="uk-margin">
<label class="uk-form-label" for="email">Email</label>
<div class="uk-form-controls">
<input class="uk-input" id="email" name="email" type="text">
</div>
</div>
<div class="uk-margin">
<label class="uk-form-label" for="message">Message</label>
<div class="uk-form-controls">
<textarea class="uk-textarea" id="message" name="message" rows="5"></textarea>
</div>
</div>
<div class="uk-margin">
<button class="uk-button uk-button-primary">Submit</button>
</div>
</fieldset>
</form>
To prepare, you will need to do the following:
- Add
data-error="*"
attributes for elements that will be displayed with the error text. - For FormIt compatibility, placeholders with values and errors must be specified.
- In UIkit, invalid status is specified by the
uk-form-danger
class, so you need to specify it in thefetchit.frontend.input.invalid.class
system setting.
INFO
Markup validators still swear by the empty action
attribute, so you must specify a link to the page in it.
modx
<form>
<form action="[[~[[*id]]]]" method="post">
<fieldset class="uk-fieldset">
<legend class="uk-legend">Form legend</legend>
<div class="uk-margin">
<label class="uk-form-label" for="name">Name</label>
<div class="uk-form-controls">
<input class="uk-input" id="name" name="name" type="text">
<input class="uk-input" id="name" name="name" type="text" value="[[+fi.name]]">
<span class="uk-text-danger" data-error="name">[[+fi.error.name]]</span>
</div>
</div>
<div class="uk-margin">
<label class="uk-form-label" for="email">Email</label>
<div class="uk-form-controls">
<input class="uk-input" id="email" name="email" type="text">
<input class="uk-input" id="email" name="email" type="text" value="[[+fi.email]]">
<span class="uk-text-danger" data-error="email">[[+fi.error.name]]</span>
</div>
</div>
<div class="uk-margin">
<label class="uk-form-label" for="message">Message</label>
<div class="uk-form-controls">
<textarea class="uk-textarea" id="message" name="message" rows="5"></textarea>
<textarea class="uk-textarea" id="message" name="message" rows="5">[[+fi.message]]</textarea>
<span class="uk-text-danger" data-error="message">[[+fi.error.message]]</span>
</div>
</div>
<div class="uk-margin">
<button class="uk-button uk-button-primary">Submit</button>
</div>
</fieldset>
</form>