diff options
author | svncommit <devs@roundcube.net> | 2007-10-15 09:17:08 +0000 |
---|---|---|
committer | svncommit <devs@roundcube.net> | 2007-10-15 09:17:08 +0000 |
commit | 97a656643866f16289264954be961aa3f314ac20 (patch) | |
tree | 84848c4778e41a58566a1afed585795e9580aca7 /program/steps/settings | |
parent | 092bc0bca51ce7830f413c600789ddc89981da67 (diff) |
When a parent folder is deleted, delete the children immediately, instead of one-by-one as r833 did.
Diffstat (limited to 'program/steps/settings')
-rw-r--r-- | program/steps/settings/manage_folders.inc | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/program/steps/settings/manage_folders.inc b/program/steps/settings/manage_folders.inc index 344e40422..4d5882f6e 100644 --- a/program/steps/settings/manage_folders.inc +++ b/program/steps/settings/manage_folders.inc @@ -97,12 +97,18 @@ else if ($_action=='rename-folder') // delete an existing IMAP mailbox else if ($_action=='delete-folder') { + $a_mboxes = array_merge($IMAP->list_mailboxes(), $IMAP->list_unsubscribed()); + $delimiter = $IMAP->get_hierarchy_delimiter(); + if ($mboxes = get_input_value('_mboxes', RCUBE_INPUT_POST)) $deleted = $IMAP->delete_mailbox(array($mboxes)); if ($OUTPUT->ajax_call && $deleted) { $OUTPUT->command('remove_folder_row', get_input_value('_mboxes', RCUBE_INPUT_POST)); + foreach ($a_mboxes as $mbox) + if (preg_match('/^'.preg_quote(get_input_value('_mboxes', RCUBE_INPUT_POST).$delimiter).'/', $mbox)) + $OUTPUT->command('remove_folder_row', $mbox); $OUTPUT->show_message('folderdeleted', 'confirmation'); $OUTPUT->send(); } |