form.js
1.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
$(function(){
activateNestedForms();
});
function activateNestedForms() {
$('.nested-wrapper').each(function(){
var wrapper = $(this);
makeNestedItemsDestroyable(wrapper);
var addLink = $('<a/>').text('add another').addClass('add-nested');
addLink.click(appendNestedItem);
wrapper.append(addLink);
});
$('.nested a.remove-nested').live('click',removeNestedItem);
}
function makeNestedItemsDestroyable(wrapper) {
wrapper.find('.nested').each(function(){
var nestedItem = $(this);
var destroyLink = $('<a/>').text('remove').addClass('remove-nested');
destroyLink.css('float','right');
nestedItem.find('label').first().prepend(destroyLink);
})
}
function appendNestedItem() {
var addLink = $(this);
var nestedItem = addLink.parent().find('.nested').first().clone();
nestedItem.find('input, select').each(function(){
var input = $(this);
var timestamp = new Date();
timestamp = timestamp.valueOf();
input.attr('id', input.attr('id').replace(/([_\[])\d+([\]_])/,'$1'+timestamp+'$2'));
input.attr('name', input.attr('name').replace(/([_\[])\d+([\]_])/,'$1'+timestamp+'$2'));
input.val('');
});
addLink.before(nestedItem);
}
function removeNestedItem() {
var destroyLink = $(this);
var nestedItem = destroyLink.closest('.nested');
var inputNameExample = nestedItem.find('input').first().attr('name');
var idFieldName = inputNameExample.replace(/\[[^\]]*\]$/,'[id]');
if($("input[name='"+idFieldName+"']").length) {
var destroyFlagName = inputNameExample.replace(/\[[^\]]*\]$/,'[_destroy]')
var destroyFlag = $('<input/>').attr('name',destroyFlagName).attr('type','hidden').val('true');
$("input[name='"+idFieldName+"']").after(destroyFlag);
nestedItem.hide();
} else {
nestedItem.remove();
}
}