mirror of
https://github.com/cytopia/devilbox.git
synced 2025-01-01 02:26:40 +00:00
91 lines
2.7 KiB
JavaScript
91 lines
2.7 KiB
JavaScript
|
$(document).ready(function() {
|
||
|
|
||
|
/* init some needed tags and values */
|
||
|
|
||
|
$('table#data').wrap('<div id="fkcontainer" class="fk" />');
|
||
|
$('#fkcontainer').append('<div id="root" />');
|
||
|
|
||
|
jQuery.ppa = {
|
||
|
root: $('#root')
|
||
|
};
|
||
|
|
||
|
$("a.fk").live('click', function (event) {
|
||
|
/* make the cursor being a waiting cursor */
|
||
|
$('body').css('cursor','wait');
|
||
|
|
||
|
query = $.ajax({
|
||
|
type: 'GET',
|
||
|
dataType: 'html',
|
||
|
data: {action:'dobrowsefk'},
|
||
|
url: $(this).attr('href'),
|
||
|
cache: false,
|
||
|
context: $(this),
|
||
|
contentType: 'application/x-www-form-urlencoded',
|
||
|
success: function(answer) {
|
||
|
pdiv = this.closest('div.fk');
|
||
|
divclass = this.attr('class').split(' ')[1];
|
||
|
|
||
|
/* if we are clicking on a FK from the original table
|
||
|
(level 0), we are using the #root div as parent-div */
|
||
|
if (pdiv[0].id == 'fkcontainer') {
|
||
|
/* computing top position, which is the topid as well */
|
||
|
var top = this.position().top + 2 + this.height();
|
||
|
/* if the requested top position is different than
|
||
|
the previous topid position of #root, empty and position it */
|
||
|
if (top != jQuery.ppa.root.topid)
|
||
|
jQuery.ppa.root.empty()
|
||
|
.css({
|
||
|
left: (pdiv.position().left) +'px',
|
||
|
top: top + 'px'
|
||
|
})
|
||
|
/* this "topid" allows to track if we are
|
||
|
opening a FK from the same line in the original table */
|
||
|
.topid = top;
|
||
|
|
||
|
pdiv = jQuery.ppa.root;
|
||
|
|
||
|
/* Remove equal rows in the root div */
|
||
|
jQuery.ppa.root.children('.'+divclass).remove();
|
||
|
}
|
||
|
else {
|
||
|
/* Remove equal rows in the pdiv */
|
||
|
pdiv.children('div.'+divclass).remove();
|
||
|
}
|
||
|
|
||
|
/* creating the data div */
|
||
|
newdiv = $('<div class="fk '+divclass+'">').html(answer);
|
||
|
|
||
|
/* highlight referencing fields */
|
||
|
newdiv.data('ref', this).data('refclass', $(this).attr('class').split(' ')[1])
|
||
|
.mouseenter(function (event) {
|
||
|
$(this).data('ref').closest('tr').find('a.'+$(this).data('refclass')).closest('div').addClass('highlight');
|
||
|
})
|
||
|
.mouseleave(function (event) {
|
||
|
$(this).data('ref').closest('tr').find('a.'+$(this).data('refclass')).closest('div').removeClass('highlight');
|
||
|
});
|
||
|
|
||
|
/* appending it to the level-1 div */
|
||
|
pdiv.append(newdiv);
|
||
|
},
|
||
|
|
||
|
error: function() {
|
||
|
this.closest('div.fk').append('<p class="errmsg">'+Display.errmsg+'</p>');
|
||
|
},
|
||
|
|
||
|
complete: function () {
|
||
|
$('body').css('cursor','auto');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
return false; // do not refresh the page
|
||
|
});
|
||
|
|
||
|
$(".fk_delete").live('click', function (event) {
|
||
|
with($(this).closest('div')) {
|
||
|
data('ref').closest('tr').find('a.'+data('refclass')).closest('div').removeClass('highlight');
|
||
|
remove();
|
||
|
}
|
||
|
return false; // do not refresh the page
|
||
|
});
|
||
|
});
|