fixed the implementation according to PR review, now validates all table names, when multiple are present, and uses gon gem

This commit is contained in:
Zanz2 2018-09-28 13:13:25 +02:00
parent 7d093fa11d
commit c6936bc71e

View file

@ -545,21 +545,29 @@
var $tinyMCEInput = TinyMCE.getContent();
var descriptionValid = textValidator(ev, $descrTextarea, 0,
<%= Constants::TEXT_MAX_LENGTH %>, false, $tinyMCEInput);
var $table_names = $form.find(".table_name");
var table_nameValid;
if ($table_names.length > 0) // if table exists check its title, if not, its validated
{
table_nameValid = textValidator(ev, $table_names, 1,
<%= Constants::NAME_MAX_LENGTH %>);
var tableNamesValidArray = [];
// iterate over table titles and validate their length
$form.find(".table_name").each(function(index , tableName) {
if (tableName.value.length > 0) {
tableNamesValidArray[index] = textValidator(ev, tableName, 1,
gon.global.NAME_MAX_LENGTH);
} else {
table_nameValid = true
tableNamesValidArray[index] = true;
}
});
var tableNamesValid = true;
// passes if all table names are valid
for (var i=0;i<tableNamesValidArray.length;i++){
if(tableNamesValidArray[i] !== true){
tableNamesValid = false;
break;
}
}
if (DragNDropSteps.filesStatus() &&
checklistsValid &&
nameValid &&
descriptionValid &&
table_nameValid ) {
tableNamesValid ) {
$form.find("[data-role='editable-table']").each(function() {
var hot = $(this).find(".hot").handsontable('getInstance');