From 2a6e7b5e3c8a16bf2c3e1e91bd953e7c073612f2 Mon Sep 17 00:00:00 2001 From: "Endi S. Dewata" Date: Fri, 4 Mar 2011 15:12:41 -0600 Subject: Fixed memory leak caused by DNS record deleter dialog. Ticket 1054 --- install/ui/policy.js | 130 +++++++++++++++++++++++++++++---------------------- 1 file changed, 74 insertions(+), 56 deletions(-) (limited to 'install') diff --git a/install/ui/policy.js b/install/ui/policy.js index 784f97cf..8c954288 100644 --- a/install/ui/policy.js +++ b/install/ui/policy.js @@ -209,79 +209,97 @@ IPA.records_facet = function (spec){ thead.find("INPUT[type='checkbox']"). attr('checked', false); - var i = 0; - var tbody = records_table.find('tbody'); + var records = []; - var delete_dialog = $('
', { - title: IPA.messages.buttons.remove - }); - var to_delete_table = - $(''+ - ''+ - '
ResourceType
').appendTo(delete_dialog); - - var to_delete_body = to_delete_table.find('tbody'); - var delete_list = []; - tbody.find("INPUT[type='checkbox']").each( - function(index, box){ - if (box.checked){ - var tr = $(box).parents('tr'); - var resource = $(tr).find('[title="idnsname"]').text(); - var type = $(tr).find('[title="type"]'). - text().toLowerCase(); - var data = $(tr).find('[title="data"]').text(); - var rectype=type+"record"; - - var options = {}; - options[rectype]=data; - - var command = { - "method":"dnsrecord_del", - "params":[[zone,resource], options]}; - delete_list.push(command); - to_delete_body.append( - $(''). - append($('',{html:resource}). - after($('',{html:type})))); - } + $('input[type=checkbox]:checked', tbody).each( + function(index, input){ + var tr = $(input).parents('tr'); + var resource = $('[title=idnsname]', tr).text(); + var type = $('[title=type]', tr).text().toLowerCase(); + var data = $('[title=data]', tr).text(); + + records.push({ + resource: resource, + type: type, + data: data + }); } ); - function delete_on_click() { - var delete_count = delete_list.length; - function delete_complete(){ - reload(); - delete_dialog.dialog('close'); + if (records.length === 0){ + return; + } + + var dialog = IPA.dialog({ + title: IPA.messages.buttons.remove + }); + + dialog.create = function() { + + var to_delete_table = + $(''+ + ''+ + '
ResourceType
').appendTo(dialog.container); + + var to_delete_body = to_delete_table.find('tbody'); + + for (var i=0; i').appendTo(to_delete_body); + + $('', { + html: record.resource + }).appendTo(tr); + + $('', { + html: record.type + }).appendTo(tr); } - IPA.cmd('batch', delete_list, {}, - delete_complete,delete_complete); - } + $('

', { + text: IPA.messages.search.delete_confirm + }).appendTo(dialog.container); + }; - function cancel_on_click() { - delete_dialog.dialog('close'); - } + dialog.add_button(IPA.messages.buttons.remove, function() { + var batch = IPA.batch_command({ + on_success: function() { + reload(); + dialog.close(); + }, + on_error: function() { + reload(); + dialog.close(); + } + }); - if (delete_list.length === 0){ - return; - } - delete_dialog.append($('

', - {text: IPA.messages.search.delete_confirm})); + for (var i=0; i