site.js 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. "use strict";
  2. $(function () {
  3. $('.fieldlist').each(function() {
  4. var $this=$(this);
  5. var lis=$this.children('li');
  6. lis.first().children(':first').after(' <button class="btn btn-mini" type="button"><i class="icon-plus"></i></button>');
  7. lis.first().children('button').click(function() {
  8. clone_fieldlist($this.children('li:last'));
  9. });
  10. lis=lis.slice(1);
  11. lis.each(function() {
  12. append_remove_button($(this));
  13. });
  14. });
  15. $('.selectpicker').selectpicker();
  16. });
  17. function change_input_num(li, new_num, reset=false) {
  18. li.find('input,select').each(function() {
  19. var id = $(this).attr('id').replace(/^(.*)-\d{1,4}/, '$1-'+new_num);
  20. $(this).attr({'name': id, 'id': id});
  21. if(reset)
  22. $(this).val('').removeAttr('checked');
  23. });
  24. }
  25. function append_remove_button(li) {
  26. li.children(':first').after(' <button class="btn btn-mini" type="button"><i class="icon-minus"></i></button>');
  27. li.children('button').click(function() {
  28. var ul=li.parent();
  29. li.remove();
  30. var i=0;
  31. ul.children('li').each(function() {
  32. change_input_num($(this), i);
  33. i++;
  34. });
  35. });
  36. };
  37. function clone_fieldlist(el) {
  38. var new_element = el.clone(true);
  39. var elem_id = new_element.find(':input')[0].id;
  40. var elem_num = parseInt(elem_id.replace(/^.*-(\d{1,4})/, '$1')) + 1;
  41. change_input_num(new_element, elem_num, true);
  42. new_element.children('button').remove();
  43. new_element.children('.help-inline.error-list').remove();
  44. new_element.find('.bootstrap-select').remove();
  45. append_remove_button(new_element);
  46. new_element.find('.selectpicker').data('selectpicker', null).selectpicker();
  47. el.after(new_element);
  48. }