formset woes
This commit is contained in:
parent
d0eaa41bb1
commit
4e374c8d39
128
itf/static/js/jquery.formset.js
Normal file
128
itf/static/js/jquery.formset.js
Normal file
|
@ -0,0 +1,128 @@
|
||||||
|
/**
|
||||||
|
* jQuery Formset 1.1
|
||||||
|
* @author Stanislaus Madueke (stan DOT madueke AT gmail DOT com)
|
||||||
|
* @requires jQuery 1.2.6 or later
|
||||||
|
*
|
||||||
|
* Copyright (c) 2009, Stanislaus Madueke
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Licensed under the New BSD License
|
||||||
|
* See: http://www.opensource.org/licenses/bsd-license.php
|
||||||
|
*/
|
||||||
|
(function($) {
|
||||||
|
$.fn.formset = function(opts)
|
||||||
|
{
|
||||||
|
var options = $.extend({}, $.fn.formset.defaults, opts);
|
||||||
|
|
||||||
|
var updateElementIndex = function(el, prefix, ndx) {
|
||||||
|
var id_regex = new RegExp('(' + prefix + '-\\d+)');
|
||||||
|
var replacement = prefix + '-' + ndx;
|
||||||
|
if ($(el).attr("for")) $(el).attr("for", $(el).attr("for").replace(id_regex, replacement));
|
||||||
|
if (el.id) el.id = el.id.replace(id_regex, replacement);
|
||||||
|
if (el.name) el.name = el.name.replace(id_regex, replacement);
|
||||||
|
};
|
||||||
|
|
||||||
|
$(this).each(function(i) {
|
||||||
|
$(this).addClass(options.formCssClass);
|
||||||
|
if ($(this).is('TR')) {
|
||||||
|
// If the forms are laid out in table rows, insert
|
||||||
|
// the remove button into the last table cell:
|
||||||
|
$(this).children(':last').append('<a class="' + options.deleteCssClass +'" href="javascript:void(0)">' + options.deleteText + '</a>');
|
||||||
|
} else if ($(this).is('UL') || $(this).is('OL')) {
|
||||||
|
// If they're laid out as an ordered/unordered list,
|
||||||
|
// insert an <li> after the last list item:
|
||||||
|
$(this).append('<li><a class="' + options.deleteCssClass + '" href="javascript:void(0)">' + options.deleteText +'</a></li>');
|
||||||
|
} else {
|
||||||
|
// Otherwise, just insert the remove button as the
|
||||||
|
// last child element of the form's container:
|
||||||
|
$(this).append('<a class="' + options.deleteCssClass + '" href="javascript:void(0)">' + options.deleteText +'</a>');
|
||||||
|
}
|
||||||
|
$(this).find('a.' + options.deleteCssClass).click(function() {
|
||||||
|
// Remove the parent form containing this button:
|
||||||
|
var row = $(this).parents('.' + options.formCssClass);
|
||||||
|
row.remove();
|
||||||
|
// If a post-delete callback was provided, call it with the deleted form:
|
||||||
|
if (options.removed) options.removed(row);
|
||||||
|
// Update the TOTAL_FORMS form count.
|
||||||
|
// Also, update names and ids for all remaining form controls
|
||||||
|
// so they remain in sequence:
|
||||||
|
var forms = $('.' + options.formCssClass);
|
||||||
|
$('#id_' + options.prefix + '-TOTAL_FORMS').val(forms.length);
|
||||||
|
// If there's only one form left, disable its delete button:
|
||||||
|
if (forms.length == 1) { $('a.' + options.deleteCssClass).hide(); }
|
||||||
|
for (var i=0, formCount=forms.length; i<formCount; i++) {
|
||||||
|
$(forms.get(i)).find('input,select,textarea,label').each(function() {
|
||||||
|
updateElementIndex(this, options.prefix, i);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
if ($(this).length) {
|
||||||
|
var $addBtn;
|
||||||
|
if ($(this).attr('tagName') == 'TR') {
|
||||||
|
// If forms are laid out as table rows, insert the
|
||||||
|
// "add" button in a new table row:
|
||||||
|
var numCols = this.eq(0).children().length;
|
||||||
|
$(this).parent().append('<tr><td colspan="' + numCols + '"><a class="' + options.addCssClass + '" href="javascript:void(0)">' + options.addText + '</a></tr>');
|
||||||
|
$addBtn = $(this).parent().find('tr:last a');
|
||||||
|
} else {
|
||||||
|
// Otherwise, insert it immediately after the last form:
|
||||||
|
$(this).filter(':last').after('<a class="' + options.addCssClass + '" href="javascript:void(0)">' + options.addText + '</a>');
|
||||||
|
$addBtn = $(this).filter(':last').next();
|
||||||
|
}
|
||||||
|
$addBtn.click(function() {
|
||||||
|
var nextIndex = parseInt($('#id_' + options.prefix + '-TOTAL_FORMS').val());
|
||||||
|
var row = $('.' + options.formCssClass + ' fieldset:first').clone().get(0);
|
||||||
|
$(row).removeAttr('id').insertAfter($('.' + options.formCssClass + ':last'));
|
||||||
|
$(row).find('input,select,textarea,label').each(function() {
|
||||||
|
updateElementIndex(this, options.prefix, nextIndex);
|
||||||
|
// If this is a checkbox or radiobutton, set uncheck it.
|
||||||
|
// Fix for Issue 1, reported by Wilson.Andrew.J:
|
||||||
|
var elem = $(this);
|
||||||
|
if (elem.is('input:checkbox') || elem.is('input:radio')) {
|
||||||
|
elem.attr('checked', false);
|
||||||
|
} else {
|
||||||
|
elem.val('');
|
||||||
|
}
|
||||||
|
if (elem.hasClass("select2class")) {
|
||||||
|
//console.log(elem);
|
||||||
|
elem.attr("data-id", "");
|
||||||
|
elem.attr("data-title", "");
|
||||||
|
$(row).find(".select2-container").remove();
|
||||||
|
|
||||||
|
elem.itfSelect2();
|
||||||
|
//console.log($(row));
|
||||||
|
//$(row).find(".select2-container").remove();
|
||||||
|
//elem.itfSelect2();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var formCount = nextIndex + 1;
|
||||||
|
$('#id_' + options.prefix + '-TOTAL_FORMS').val(formCount);
|
||||||
|
// If we've got more than one form, enable delete buttons:
|
||||||
|
if (formCount > 1) { $('a.' + options.deleteCssClass).show(); }
|
||||||
|
// If a post-add callback was supplied, call it with the added form:
|
||||||
|
if (options.added) options.added($(row));
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the formset is initialized with a single form, hide the delete button:
|
||||||
|
if ($(this).length == 1) { $('a.' + options.deleteCssClass).hide(); }
|
||||||
|
|
||||||
|
return $(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Setup plugin defaults */
|
||||||
|
$.fn.formset.defaults = {
|
||||||
|
prefix: 'form', // The form prefix for your django formset
|
||||||
|
addText: 'add another', // Text for the add link
|
||||||
|
deleteText: 'remove', // Text for the delete link
|
||||||
|
addCssClass: 'add-row', // CSS class applied to the add link
|
||||||
|
deleteCssClass: 'delete-row', // CSS class applied to the delete link
|
||||||
|
formCssClass: 'dynamic-form', // CSS class applied to each form in a formset
|
||||||
|
added: null, // Function called each time a new form is added
|
||||||
|
removed: null // Function called each time a form is deleted
|
||||||
|
}
|
||||||
|
})(jQuery)
|
|
@ -17,32 +17,21 @@
|
||||||
.select2-input {
|
.select2-input {
|
||||||
width: 200px !important;
|
width: 200px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.delete-row {
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
<!-- uni-form JS library, optional -->
|
<!-- uni-form JS library, optional -->
|
||||||
<script src="/static/uni_form/uni-form.jquery.js" type="text/javascript"></script>
|
<script src="/static/uni_form/uni-form.jquery.js" type="text/javascript"></script>
|
||||||
<script src="/static/js/select2.js" type="text/javascript"></script>
|
<script src="/static/js/select2.js" type="text/javascript"></script>
|
||||||
<script src="/static/js/jquery.formset.min.js"></script>
|
<script src="/static/js/jquery.formset.js"></script>
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$(function(){
|
|
||||||
$('form.uniForm').uniform();
|
|
||||||
/*
|
|
||||||
$('select').select2({
|
|
||||||
|
|
||||||
});
|
$.fn.itfSelect2 = function() {
|
||||||
*/
|
return this.each(function() {
|
||||||
/*
|
|
||||||
sampleData = [
|
|
||||||
{
|
|
||||||
'id': 'foo',
|
|
||||||
'text': 'some text',
|
|
||||||
'first_name': 'some',
|
|
||||||
'last_name': 'test'
|
|
||||||
}
|
|
||||||
];
|
|
||||||
*/
|
|
||||||
$('.select2class').each(function() {
|
|
||||||
var $this = $(this);
|
var $this = $(this);
|
||||||
var ctype_id = $this.attr("data-ctype");
|
var ctype_id = $this.attr("data-ctype");
|
||||||
var url = '/autocomplete/' + ctype_id;
|
var url = '/autocomplete/' + ctype_id;
|
||||||
|
@ -82,8 +71,31 @@ $(function(){
|
||||||
var title = $this.attr("data-title");
|
var title = $this.attr("data-title");
|
||||||
$this.select2("val", {'id': id, 'title': title});
|
$this.select2("val", {'id': id, 'title': title});
|
||||||
}
|
}
|
||||||
|
//return this;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$(function(){
|
||||||
|
$('form.uniForm').uniform();
|
||||||
|
/*
|
||||||
|
$('select').select2({
|
||||||
|
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
sampleData = [
|
||||||
|
{
|
||||||
|
'id': 'foo',
|
||||||
|
'text': 'some text',
|
||||||
|
'first_name': 'some',
|
||||||
|
'last_name': 'test'
|
||||||
|
}
|
||||||
|
];
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
$('.select2class').itfSelect2();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
$('.select2class').select2({
|
$('.select2class').select2({
|
||||||
|
|
Loading…
Reference in New Issue
Block a user