Skip to content
This repository has been archived by the owner on Oct 12, 2019. It is now read-only.

Commit

Permalink
extend option classes, allows customization of form error + success c…
Browse files Browse the repository at this point in the history
…lasses
  • Loading branch information
Tabea David committed Sep 14, 2017
1 parent ace19c3 commit 8d84715
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 28 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
# Changelog

### 1.0.4 (2017-09-14)

- extend option `classes`
- allows customization of classes for form error and success

### 1.0.3 (2017-05-14)

- corrects typo in success message: **The translation string has been changed, some may need to translate it again!** // thanks @szabesz
Expand Down
10 changes: 6 additions & 4 deletions SimpleContactForm.module
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ use \Jos\Mailer;
* See README.md for usage instructions.
*
* @author Tabea David <[email protected]>
* @version 1.0.3
* @version 1.0.4
* @copyright Copyright (c) 2017
* @see https://github.com/justonestep/processwire-simplecontactform
* @see http://www.processwire.com
Expand Down Expand Up @@ -92,6 +92,8 @@ class SimpleContactForm extends WireData implements Module {
*/
static protected $classes = array(
'form' => 'form js-simplecontactform', // additional clases for inputfieldform (optional)
'form_error' => 'form--error--message',
'form_success' => 'form--success--message',
'list' => 'fields',
'list_clearfix' => 'clearfix',
'item' => 'form__item form__item--{name}',
Expand Down Expand Up @@ -216,12 +218,12 @@ class SimpleContactForm extends WireData implements Module {
$spamProtector->getAnimal(),
$spamProtector->getFruit()
));
$form->appendMarkup .= '<p class="form--error--message">' . $form->getErrors()[0] . '</p>';
$form->appendMarkup .= "<p class='{$form->getClasses()['form_error']}'>{$form->getErrors()[0]}</p>";
$d = $form->get('scf-date');
$d->attr('value', time());
}
} else {
$form->appendMarkup .= "<p class='form--error--message'>{$this->errorMessage}</p>";
$form->appendMarkup .= "<p class='{$form->getClasses()['form_error']}'>{$this->errorMessage}</p>";
}

// send mail
Expand All @@ -233,7 +235,7 @@ class SimpleContactForm extends WireData implements Module {
$this->session->redirect($this->pages->get($p)->url);
} else {
$text = $this->_('Your contact request has been send successfully!');
$out = "<p class='form--success--message'>{$this->successMessage}</p>";
$out = "<p class='{$form->getClasses()['form_success']}'>{$this->successMessage}</p>";
}
}
}
Expand Down
50 changes: 26 additions & 24 deletions doc/overwrite-classes-and-markup.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,17 +31,17 @@ Below is the list of all available customization options copied from [ProcessWir
*
*/
static protected $defaultMarkup = array(
'list' => "<ul {attrs}>{out}</ul>",
'item' => "<li {attrs}>{out}</li>",
'item_label' => "<label class='InputfieldHeader ui-widget-header{class}' for='{for}'>{out}</label>",
'item_label_hidden' => "<label class='InputfieldHeader InputfieldHeaderHidden ui-widget-header{class}'><span>{out}</span></label>",
'item_content' => "<div class='InputfieldContent ui-widget-content{class}'>{out}</div>",
'item_error' => "<p class='InputfieldError ui-state-error'><i class='fa fa-fw fa-flash'></i><span>{out}</span></p>",
'item_description' => "<p class='description'>{out}</p>",
'item_head' => "<h2>{out}</h2>",
'item_notes' => "<p class='notes'>{out}</p>",
'item_icon' => "<i class='fa fa-fw fa-{name}'></i> ",
'item_toggle' => "<i class='toggle-icon fa fa-fw fa-angle-down' data-to='fa-angle-down fa-angle-right'></i>",
'list' => "{out}\n",
'item' => "\n\t<div {attrs}>\n{out}\n\t</div>",
'item_label' => "\n\t\t<label class='form__item--label' for='{for}'>{out}</label>",
'item_label_hidden' => "\n\t\t<label class='field__header field__header--hidden {class}'>{out}</label>",
'item_content' => "{out}",
'item_error' => "\n<p class='field--error--message'>{out}</p>",
'item_description' => "\n<p class='field__description'>{out}</p>",
'item_head' => "\n<h2>{out}</h2>",
'item_notes' => "\n<p class='field__notes'>{out}</p>",
'item_icon' => "",
'item_toggle' => "",
// ALSO:
// InputfieldAnything => array( any of the properties above to override on a per-Inputifeld basis)
);
Expand All @@ -51,19 +51,21 @@ static protected $defaultMarkup = array(
*
*/
static protected $defaultClasses = array(
'form' => '', // additional clases for InputfieldForm (optional)
'list' => 'Inputfields',
'list_clearfix' => 'ui-helper-clearfix',
'item' => 'Inputfield {class} Inputfield_{name} ui-widget',
'item_label' => '', // additional classes for InputfieldHeader (optional)
'item_content' => '', // additional classes for InputfieldContent (optional)
'item_required' => 'InputfieldStateRequired', // class is for Inputfield
'item_error' => 'ui-state-error InputfieldStateError', // note: not the same as markup[item_error], class is for Inputfield
'item_collapsed' => 'InputfieldStateCollapsed',
'item_column_width' => 'InputfieldColumnWidth',
'item_column_width_first' => 'InputfieldColumnWidthFirst',
'item_show_if' => 'InputfieldStateShowIf',
'item_required_if' => 'InputfieldStateRequiredIf'
'form' => 'form js-simplecontactform', // additional clases for inputfieldform (optional)
'form_error' => 'form--error--message',
'form_success' => 'form--success--message',
'list' => 'fields',
'list_clearfix' => 'clearfix',
'item' => 'form__item form__item--{name}',
'item_label' => '', // additional classes for inputfieldheader (optional)
'item_content' => '', // additional classes for inputfieldcontent (optional)
'item_required' => 'field--required', // class is for inputfield
'item_error' => 'field--error', // note: not the same as markup[item_error], class is for inputfield
'item_collapsed' => 'field--collapsed',
'item_column_width' => 'field__column',
'item_column_width_first' => 'field__column--first',
'item_show_if' => 'field--show-if',
'item_required_if' => 'field--required-if'
// ALSO:
// InputfieldAnything => array( any of the properties above to override on a per-Inputifeld basis)
);
Expand Down

0 comments on commit 8d84715

Please sign in to comment.