From 9e26034801fe505a481d474e06bfc806cd548598 Mon Sep 17 00:00:00 2001
From: Aleksander Machniak <alec@alec.pl>
Date: Fri, 09 Jan 2015 03:06:01 -0500
Subject: [PATCH] Fix bug where max_group_members was ignored when adding a new contact (#1490214)

---
 CHANGELOG                          |    2 ++
 program/steps/addressbook/save.inc |   14 ++++++++------
 program/js/app.js                  |    3 +++
 3 files changed, 13 insertions(+), 6 deletions(-)

diff --git a/CHANGELOG b/CHANGELOG
index 7f26bd8..d49c3f4 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,6 +1,8 @@
 CHANGELOG Roundcube Webmail
 ===========================
 
+- Fix bug where max_group_members was ignored when adding a new contact (#1490214)
+
 RELEASE 1.1-rc
 --------------
 - Update jQuery to version 2.1.3
diff --git a/program/js/app.js b/program/js/app.js
index 29a53bb..c792bb6 100644
--- a/program/js/app.js
+++ b/program/js/app.js
@@ -4774,6 +4774,9 @@
     if (!src)
       src = this.env.source;
 
+    if (refresh)
+      group = this.env.group;
+
     if (page && this.current_page == page && src == this.env.source && group == this.env.group)
       return false;
 
diff --git a/program/steps/addressbook/save.inc b/program/steps/addressbook/save.inc
index 4f30fd4..518625c 100644
--- a/program/steps/addressbook/save.inc
+++ b/program/steps/addressbook/save.inc
@@ -226,13 +226,15 @@
             $plugin = $RCMAIL->plugins->exec_hook('group_addmembers', array(
                 'group_id' => $CONTACTS->group_id, 'ids' => $insert_id, 'source' => $source));
 
-            $counts = $CONTACTS->count();
-
             if (!$plugin['abort']) {
-                if (($maxnum = $RCMAIL->config->get('max_group_members', 0)) && ($counts->count + 1 > $maxnum))
-                    $OUTPUT->show_message('maxgroupmembersreached', 'warning', array('max' => $maxnum));
-
-                $CONTACTS->add_to_group($plugin['group_id'], $plugin['ids']);
+                if (($maxnum = $RCMAIL->config->get('max_group_members', 0)) && ($CONTACTS->count()->count + 1 > $maxnum)) {
+                    // @FIXME: should we remove the contact?
+                    $msgtext = $RCMAIL->gettext(array('name' => 'maxgroupmembersreached', 'vars' => array('max' => $maxnum)));
+                    $OUTPUT->command('parent.display_message', $msgtext, 'warning');
+                }
+                else {
+                    $CONTACTS->add_to_group($plugin['group_id'], $plugin['ids']);
+                }
             }
         }
 

--
Gitblit v1.9.1