diff options
author | thomascube <thomas@roundcube.net> | 2011-10-10 20:15:46 +0000 |
---|---|---|
committer | thomascube <thomas@roundcube.net> | 2011-10-10 20:15:46 +0000 |
commit | dc6c4f4a28652f428a507b0335f418749cdbc3bd (patch) | |
tree | 336545f4b595b555631569eb73b34ea5cf0a183f /program/steps/addressbook | |
parent | a3148236ebaa7e61177e7186138997d136b88b3e (diff) |
Contact groups can have direct email addresses => distribution lists; enable 'compose' command for the selected group
Diffstat (limited to 'program/steps/addressbook')
-rw-r--r-- | program/steps/addressbook/mailto.inc | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/program/steps/addressbook/mailto.inc b/program/steps/addressbook/mailto.inc index 5996b9da7..99c022db2 100644 --- a/program/steps/addressbook/mailto.inc +++ b/program/steps/addressbook/mailto.inc @@ -21,6 +21,7 @@ $cids = rcmail_get_cids(); $mailto = array(); +$recipients = null; foreach ($cids as $source => $cid) { @@ -31,11 +32,34 @@ foreach ($cids as $source => $cid) $CONTACTS->set_page(1); $CONTACTS->set_pagesize(count($cid) + 2); // +2 to skip counting query $recipients = $CONTACTS->search($CONTACTS->primary_key, $cid, false, true, true, 'email'); + } +} + +if (!empty($_REQUEST['_gid']) && isset($_REQUEST['_source'])) +{ + $source = get_input_value('_source', RCUBE_INPUT_GPC); + $CONTACTS = $RCMAIL->get_address_book($source); + + $group_id = get_input_value('_gid', RCUBE_INPUT_GPC); + $group_data = $CONTACTS->get_group($group_id); + + // group has an email address assigned: use that + if ($group_data['email']) { + $mailto[] = format_email_recipient($group_data['email'][0], $group_data['name']); + } + else if ($CONTACTS->ready) { + $CONTACTS->set_group($group_id); + $CONTACTS->set_page(1); + $CONTACTS->set_pagesize(200); // limit somehow + $recipients = $CONTACTS->list_records(); + } +} - while (is_object($recipients) && ($rec = $recipients->iterate())) { - $emails = $CONTACTS->get_col_values('email', $rec, true); - $mailto[] = format_email_recipient($emails[0], $rec['name']); - } +if ($recipients) +{ + while (is_object($recipients) && ($rec = $recipients->iterate())) { + $emails = $CONTACTS->get_col_values('email', $rec, true); + $mailto[] = format_email_recipient($emails[0], $rec['name']); } } |