mirror of
https://github.com/a2nt/webpack-bootstrap-ui-kit.git
synced 2024-10-22 11:05:45 +02:00
FieldUI add message, remove messages functions
This commit is contained in:
parent
23f598e8c6
commit
d7a79dc082
2
dist/js/app.js
vendored
2
dist/js/app.js
vendored
File diff suppressed because one or more lines are too long
2
dist/js/app.js.map
vendored
2
dist/js/app.js.map
vendored
File diff suppressed because one or more lines are too long
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@a2nt/ss-bootstrap-ui-webpack-boilerplate",
|
"name": "@a2nt/ss-bootstrap-ui-webpack-boilerplate",
|
||||||
"version": "1.1.1",
|
"version": "1.1.2",
|
||||||
"author": "Tony Air <tony@twma.pro>",
|
"author": "Tony Air <tony@twma.pro>",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"description": "This UI Kit allows you to build Bootstrap 4 webapp with some extra UI features. It's easy to extend and easy to convert HTML templates to CMS templates.",
|
"description": "This UI Kit allows you to build Bootstrap 4 webapp with some extra UI features. It's easy to extend and easy to convert HTML templates to CMS templates.",
|
||||||
|
@ -49,7 +49,7 @@ const FormFieldUI = (($) => {
|
|||||||
const $el = ui.$el;
|
const $el = ui.$el;
|
||||||
|
|
||||||
$el.removeClass(`${NAME}-active`);
|
$el.removeClass(`${NAME}-active`);
|
||||||
$.removeData(this._el, DATA_KEY);
|
$.removeData($el[0], DATA_KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
show() {
|
show() {
|
||||||
@ -112,6 +112,31 @@ const FormFieldUI = (($) => {
|
|||||||
$el.prop('checked', checked);
|
$el.prop('checked', checked);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
addMessage(msg, type = null, scrollTo = true) {
|
||||||
|
const ui = this;
|
||||||
|
const $field = ui.$el.closest('.field');
|
||||||
|
|
||||||
|
|
||||||
|
$field.addClass('has-message');
|
||||||
|
if (msg) {
|
||||||
|
$field.append(`<div class="message alert ${ type }">${ msg }</div>`);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (scrollTo) {
|
||||||
|
const pos = $field.offset().top;
|
||||||
|
$field.focus();
|
||||||
|
$Html.scrollTop(pos - 100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
removeMessages() {
|
||||||
|
const ui = this;
|
||||||
|
const $field = ui.$el.closest('.field');
|
||||||
|
|
||||||
|
$field.removeClass('has-message');
|
||||||
|
$field.find('.message').remove();
|
||||||
|
}
|
||||||
|
|
||||||
static _jQueryInterface() {
|
static _jQueryInterface() {
|
||||||
return this.each(function() {
|
return this.each(function() {
|
||||||
// attach functionality to el
|
// attach functionality to el
|
||||||
|
@ -7,39 +7,43 @@ const FormValidateField = (($) => {
|
|||||||
const DATA_KEY = NAME;
|
const DATA_KEY = NAME;
|
||||||
const $Html = $('html, body');
|
const $Html = $('html, body');
|
||||||
|
|
||||||
|
const FieldUI = 'jsFormFieldUI';
|
||||||
|
|
||||||
class FormValidateField {
|
class FormValidateField {
|
||||||
|
|
||||||
constructor(element) {
|
constructor(el) {
|
||||||
const ui = this;
|
const ui = this;
|
||||||
const $element = $(element);
|
const $el = $(el);
|
||||||
|
|
||||||
ui._element = element;
|
ui.$el = $el;
|
||||||
ui._actions = $element.parents('form').children('.btn-toolbar,.form-actions');
|
|
||||||
$element.data(DATA_KEY, this);
|
ui._actions = $el.parents('form').children('.btn-toolbar,.form-actions');
|
||||||
|
$el.data(DATA_KEY, this);
|
||||||
|
|
||||||
// prevent browsers checks (will do it using JS)
|
// prevent browsers checks (will do it using JS)
|
||||||
$element.attr('novalidate', 'novalidate');
|
$el.attr('novalidate', 'novalidate');
|
||||||
|
|
||||||
$element.on('change focusout', (e) => {
|
$el.on('change focusout', (e) => {
|
||||||
ui.validate(false);
|
ui.validate(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
$element.addClass(`${NAME}-active`);
|
$el.addClass(`${NAME}-active`);
|
||||||
$element.trigger(Events.FORM_INIT_VALIDATE_FIELD);
|
$el.trigger(Events.FORM_INIT_VALIDATE_FIELD);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public methods
|
// Public methods
|
||||||
dispose() {
|
dispose() {
|
||||||
const $element = $(this._element);
|
const $el = ui.$el;
|
||||||
|
|
||||||
$element.removeClass(`${NAME}-active`);
|
$el.removeClass(`${NAME}-active`);
|
||||||
$.removeData(this._element, DATA_KEY);
|
$.removeData(ui.$el[0], DATA_KEY);
|
||||||
this._element = null;
|
ui.$el = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
validate(scrollTo = true) {
|
validate(scrollTo = true) {
|
||||||
const ui = this;
|
const ui = this;
|
||||||
const $el = $(ui._element);
|
const $el = ui.$el;
|
||||||
|
|
||||||
const $field = $el.closest('.field');
|
const $field = $el.closest('.field');
|
||||||
const extraChecks = $el.data(`${NAME}-extra`);
|
const extraChecks = $el.data(`${NAME}-extra`);
|
||||||
let valid = true;
|
let valid = true;
|
||||||
@ -48,7 +52,7 @@ const FormValidateField = (($) => {
|
|||||||
const val = $el.val();
|
const val = $el.val();
|
||||||
|
|
||||||
// browser checks + required
|
// browser checks + required
|
||||||
if (!ui._element.checkValidity() ||
|
if (!ui.$el[0].checkValidity() ||
|
||||||
($el.hasClass('required') && (!val.length || !val.trim().length ||
|
($el.hasClass('required') && (!val.length || !val.trim().length ||
|
||||||
ui.isHtml(val) && !$(val).text().length
|
ui.isHtml(val) && !$(val).text().length
|
||||||
))
|
))
|
||||||
@ -97,15 +101,17 @@ const FormValidateField = (($) => {
|
|||||||
|
|
||||||
setError(scrollTo = true, msg = null) {
|
setError(scrollTo = true, msg = null) {
|
||||||
const ui = this;
|
const ui = this;
|
||||||
const $field = $(ui._element).closest('.field');
|
const fieldUI = ui.$el.data(FieldUI);
|
||||||
|
|
||||||
|
const $field = ui.$el.closest('.field');
|
||||||
const pos = $field.offset().top;
|
const pos = $field.offset().top;
|
||||||
|
|
||||||
|
ui.removeError();
|
||||||
|
|
||||||
$field.addClass('error');
|
$field.addClass('error');
|
||||||
if (msg) {
|
if (msg) {
|
||||||
$field.append(`<div class="message alert alert-error alert-danger">${ msg }</div>`);
|
fieldUI.addMessage(msg, 'alert-error alert-danger', scrollTo);
|
||||||
}
|
} else if (scrollTo) {
|
||||||
|
|
||||||
if (scrollTo) {
|
|
||||||
$field.focus();
|
$field.focus();
|
||||||
$Html.scrollTop(pos - 100);
|
$Html.scrollTop(pos - 100);
|
||||||
}
|
}
|
||||||
@ -113,24 +119,26 @@ const FormValidateField = (($) => {
|
|||||||
|
|
||||||
removeError() {
|
removeError() {
|
||||||
const ui = this;
|
const ui = this;
|
||||||
const $field = $(ui._element).closest('.field');
|
const fieldUI = ui.$el.data(FieldUI);
|
||||||
|
|
||||||
|
const $field = ui.$el.closest('.field');
|
||||||
|
|
||||||
$field.removeClass('error');
|
$field.removeClass('error');
|
||||||
|
|
||||||
$field.removeClass('holder-error');
|
$field.removeClass('holder-error');
|
||||||
$field.removeClass('holder-validation');
|
$field.removeClass('holder-validation');
|
||||||
$field.find('.message').remove();
|
$field.find('.alert-error').remove();
|
||||||
}
|
}
|
||||||
|
|
||||||
static _jQueryInterface() {
|
static _jQueryInterface() {
|
||||||
return this.each(function() {
|
return this.each(function() {
|
||||||
// attach functionality to element
|
// attach functionality to el
|
||||||
const $element = $(this);
|
const $el = $(this);
|
||||||
let data = $element.data(DATA_KEY);
|
let data = $el.data(DATA_KEY);
|
||||||
|
|
||||||
if (!data) {
|
if (!data) {
|
||||||
data = new FormValidateField(this);
|
data = new FormValidateField(this);
|
||||||
$element.data(DATA_KEY, data);
|
$el.data(DATA_KEY, data);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user