DataObjects/Core_group.php
[Pman.Core] / DataObjects / Core_group.php
index 7b2ccbe..a048f9d 100644 (file)
@@ -40,6 +40,7 @@ class Pman_Core_DataObjects_Core_group extends DB_DataObject
     // group types??
     function applyFilters($q, $au, $roo)
     {
+        var_dump($q); 
         if (!empty($q['query']['name_starts'])) {
             $v = $this->escape($q['query']['name_starts']);
             $this->whereAdd("{$this->tableName()}.name like '{$v}%'");
@@ -53,26 +54,38 @@ class Pman_Core_DataObjects_Core_group extends DB_DataObject
                 $roo->jok($core_group->memberCount());
             }
         }
-
-
+        
+        if(!empty($q['_with_member_id'])){
+            $this->selectAdd("
+                COALESCE(
+                    (SELECT id from core_group_member
+                        WHERE ...
+                        
+                        LIMIT 1
+                    ),0) as ....
+                    ");
+        }
+        
         
         $cp = DB_DataObject::Factory('core_person')->tableName();
         $cgm = DB_DataObject::Factory('core_group_member')->tableName();
         
         $this->selectAdd("
            (
-                SELECT 
-                    COUNT(core_group_member.user_id) 
+            SELECT COUNT(${cgm}.user_id) 
                 FROM 
-                    core_group_member
+                    {$cgm}
                 LEFT JOIN
-                    core_person
+                    {$cp}
                 ON
-                    core_person.id = core_group_member.user_id
+                    ${cp}.id = {$cgm}.user_id
                 WHERE
-                    core_person.active = 1
-            ) AS group_member_count            
+                    ${cgm}.group_id = {$this->tableName()}.id
+                AND
+                    ${cp}.active = 1
+                ) AS group_member_count            
         ");
+        
         /*WHERE 
             {$this->tableName()}.id = core_group_member.group_id
             AND