Permit to add multiple things in scase at the same time

This commit is contained in:
Benjamin Renard 2017-09-17 12:18:45 +02:00
parent 3de512bf7b
commit c17bf12c94
2 changed files with 47 additions and 12 deletions

View file

@ -294,28 +294,47 @@ on_li_click=function(event) {
on_li_add_click=function(event) { on_li_add_click=function(event) {
var li=$(this); var li=$(this);
var cat=li.parent().data('cat'); var cat=li.parent().data('cat');
var modal=$('#add_thing_modal'); var modal=$('#add_thing_modal');
modal.data('cat',cat); modal.data('cat',cat);
modal.modal('show'); modal.modal('show');
} }
on_valid_add_thing_modal=function (e) { on_valid_add_thing_modal=function (e) {
e.preventDefault(); e.preventDefault();
var label=$('#add_thing_label')[0].value;
if (label=='') {
alert("Vous devez saisir le nom de l'élément !");
return;
}
var modal=$('#add_thing_modal'); var modal=$('#add_thing_modal');
var scase=scases.byName($('#cats').data('scase')); var scase=scases.byName($('#cats').data('scase'));
if (scase) { if (scase) {
var cat=scase.cats.byName(modal.data('cat')); var cat=scase.cats.byName(modal.data('cat'));
if (cat) { if (cat) {
if (cat.byLabel(label)) { var labels=[];
alert("Cet élément existe déjà !"); var error=false;
$('input.add_thing_label').each(function(idx,input) {
var val=$(input).val();
if (val && val!='') {
if (labels.indexOf(val)>-1) {
alert("Deux élements ne peuvent porter le même nom !");
error=true;
return;
}
if (cat.byLabel(val)) {
alert("L'élément '"+val+"' existe déjà !");
error=true;
return;
}
labels.push(val);
}
});
if (error) {
return; return;
} }
cat.newThing(label); if (labels.length==0) {
alert("Vous devez saisir au moins un nom d'élément !");
return;
}
for (idx in labels) {
cat.newThing(labels[idx]);
}
scases.save(); scases.save();
show_scase(scase,cat.name); show_scase(scase,cat.name);
} }
@ -324,13 +343,25 @@ on_valid_add_thing_modal=function (e) {
} }
on_show_add_thing_modal=function () { on_show_add_thing_modal=function () {
$('#add_thing_label').focus(); $('input.add_thing_label_other').parent().remove();
$('input.add_thing_label').val('');
$('input.add_thing_label').first().focus();
} }
on_close_add_thing_modal=function () { on_close_add_thing_modal=function () {
$('#add_thing_modal form')[0].reset(); $('#add_thing_modal form')[0].reset();
} }
on_add_thing_label_focus=function(event) {
if ($('input.add_thing_label').last()[0] == event.target) {
var new_input_group=$('<div class="form-group"></div>');
var new_input=$('<input type="text" class="form-control add_thing_label add_thing_label_other" class="form-control" placeholder="Encore un ?"/>');
new_input_group.append(new_input);
new_input.bind('focus', on_add_thing_label_focus);
$(event.target).parent().after(new_input_group);
}
}
/*********************** /***********************
* Rename thing * Rename thing
@ -642,6 +673,7 @@ $( document ).ready( function() {
$('#back_to_scases').bind('click',on_back_to_scases_btn_click); $('#back_to_scases').bind('click',on_back_to_scases_btn_click);
$('input.add_thing_label').bind('focus',on_add_thing_label_focus);
$('#add_thing_submit').bind('click',on_valid_add_thing_modal); $('#add_thing_submit').bind('click',on_valid_add_thing_modal);
$("#add_thing_modal").on('shown.bs.modal',on_show_add_thing_modal); $("#add_thing_modal").on('shown.bs.modal',on_show_add_thing_modal);
$("#add_thing_modal").on('hidden.bs.modal',on_close_add_thing_modal); $("#add_thing_modal").on('hidden.bs.modal',on_close_add_thing_modal);

View file

@ -209,9 +209,12 @@ div.panel-heading, li.list-group-item, a {
<h4 class="modal-title">Ajouter un élément</h4> <h4 class="modal-title">Ajouter un élément</h4>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form class="form-horizontal" role="form"> <form role="form">
<div class="form-group"> <div class="form-group">
<input type='text' id='add_thing_label' class="form-control" placeholder="Nom de l'élément"/> <input type='text' class='form-control add_thing_label' class="form-control" placeholder="Nom de l'élément"/>
</div>
<div class="form-group">
<input type='text' class='form-control add_thing_label' class="form-control" placeholder="Un autre ?"/>
</div> </div>
</form> </form>
</div> </div>