silverstripe-framework/javascript/TableField.js
2011-02-02 14:27:15 +13:00

213 lines
5.8 KiB
JavaScript
Executable File

/**
* Javascript for TableField. allows the deletion of records via
* AJAX, and the addition of rows via javasript.
*
* TODO relies on include-order at the moment to override actions :/
*/
Effect.FadeOut = function(element,callback) {
element = $(element);
var oldOpacity = Element.getInlineOpacity(element);
var options = Object.extend({
from: Element.getOpacity(element) || 1.0,
to: 0.0,
afterFinishInternal: function(effect) {
effect.element.parentNode.removeChild(effect.element);
}
}, arguments[1] || {});
return new Effect.Opacity(element,options);
}
TableField = Class.create();
TableField.prototype = {
newRowID: 1,
/**
* Applies behaviour to the delete button for deleting objects via ajax.
*/
initialize: function() {
var rules = {};
rules['#'+this.id+' table.data a.deletelink'] = {
onclick: this.deleteRecord.bind(this)
};
rules['#'+this.id+' table.data a.addrow'] = {
onclick: this.addRow.bind(this)
};
Behaviour.register('TableField_'+this.id,rules);
},
/**
* Deletes the given dataobject record via an ajax request. If the record doesn't have any
* information in it, it just removes it from the form.
* to tablefield->Delete()
* @param {Object} e
*/
deleteRecord: function(e) {
var img = Event.element(e);
var link = Event.findElement(e,"a");
var row = Event.findElement(e,"tr");
var params = link.getAttribute("href").toQueryParams();
var isEmpty = true;
// Check to see if there is a dataobject to delete first, otherwise remove the row.
// or: Check if a childID is set (not present on new items)
if(
(this.hasNoValues(row,"input") && this.hasNoValues(row,"select") && this.hasNoValues(row,"textarea"))
|| params["childID"] <= 0
){
if( row.parentNode.getElementsByTagName('tr').length > 1 ) {
try { Effect.FadeOut(row); } catch (e) {
//console.log(e);
}
} else {
// clear all fields in the row
var fields = row.getElementsByTagName('input');
if( fields )
for( var i = 0; i < fields.length; i++ ) {
fields[i].value = '';
}
}
Event.stop(e);
return false;
}
// TODO ajaxErrorHandler and loading-image are dependent on cms, but formfield is in sapphire
var confirmed = confirm(ss.i18n._t('TABLEFIELD.DELETECONFIRMMESSAGE', 'Are you sure you want to delete this record?'));
if(confirmed){
img.setAttribute("src",'cms/images/network-save.gif'); // TODO doesn't work
new Ajax.Request(
link.getAttribute("href"),
{
method: 'post',
postBody: 'ajax=1' + ($('SecurityID') ? '&SecurityID=' + $('SecurityID').value : ''),
onComplete: function(response){
Effect.Fade(
row,
{
afterFinish: function(obj) {
// remove row from DOM
obj.element.parentNode.removeChild(obj.element);
// recalculate summary if needed (assumes that TableListField.js is present)
// TODO Proper inheritance
if(this._summarise) this._summarise();
// custom callback
if(this.callback_deleteRecord) this.callback_deleteRecord(e);
}.bind(this)
}
);
}.bind(this),
onFailure: ajaxErrorHandler
}
);
}
Event.stop(e);
return false;
},
/**
*
*
* @param {Object} element
* @param {Object} tagName
*/
hasNoValues: function(element,tagName){
elements = element.getElementsByTagName(tagName);
if(elements.length >= 1){
var isEmpty = true;
for(var i = 0; i < elements.length;i++){
if(elements[i].type != "hidden"){
if(elements[i].value != null && elements[i].value != ""){
//console.log(elements[i].id + ' has value');
isEmpty = false;
}
}
}
return isEmpty;
}else{
return true;
}
},
/**
* Appends a new row to the DOM.
*
* @param {Object} tableid
*/
addRow: function (e){
var table = Event.findElement(e,"table");
if(table){
// Clone the last TR
var tbody = table.tBodies[0];
var numRows = tbody.rows.length;
var newRow = tbody.rows[0].cloneNode(true);
// Get the input elements in this new row
var inputs = newRow.getElementsByTagName('input');
// For every input, set it's value to blank if it is not hidden
for(var i = 0; i < inputs.length; i++) {
if(inputs[i].type != 'hidden') {
inputs[i].value = ""
};
}
this.newRowID++;
if(newRow.id != "new"){
this.resetNames(newRow);
}
// Make sure all inputs have unique IDs
for(var i = 0; i < inputs.length; i++) {
inputs[i].id += "-" + this.newRowID;
}
// Change the ID to a unique one
newRow.id = "New_" + this.newRowID;
// Append the new row to the DOM
table.tBodies[0].appendChild(newRow);
Behaviour.apply(table);
}
Event.stop(e);
},
/**
* resets the names for all elements inside a row.
* @param {Object} row
*/
resetNames: function(row){
// Support for addressing the ID's appropriately.
for(i = 0; i < row.cells.length;i++){
for(b=0; b < row.cells[i].childNodes.length;b++){
inputElement = row.cells[i].childNodes[b];
if(inputElement.type != 'hidden') inputElement.value = "";
if(inputElement.name != null){
if(inputElement.name.substr(inputElement.name.length - 2,inputElement.name.length) != "[]"){
inputElement.name =
inputElement.name.substr(0,inputElement.name.indexOf('[')+1) + "new" +
inputElement.name.substr(inputElement.name.indexOf(']'),inputElement.name.length) + "[]";
}else{
inputElement.name =
inputElement.name.substr(0,inputElement.name.indexOf('[')+1) + "new" +
inputElement.name.substr(inputElement.name.indexOf(']'),inputElement.name.length);
}
}
}
}
}
}
TableField.applyTo('div.TableField');
if(typeof ajaxErrorHandler == 'undefined'){
ajaxErrorHandler = function(response) {
alert(response.responseText);
}
}