// 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}%'");
$roo->jok($core_group->memberCount());
}
}
-
- DB_DataObject::debugLevel(1);
- $core_group = DB_DataObject::factory('core_group');
+
+ 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();
- $cpObj->active = 1; // set the where condition with active = 1
-
+
$this->selectAdd("
(
- SELECT
- count(user_id)
- FROM
- {$cgm}
- WHERE
- {$this->tableName()}.id = {$cgm}.group_id
+ SELECT COUNT(${cgm}.user_id)
+ FROM
+ {$cgm}
+ LEFT JOIN
+ {$cp}
+ ON
+ ${cp}.id = {$cgm}.user_id
+ WHERE
+ ${cgm}.group_id = {$this->tableName()}.id
+ AND
+ ${cp}.active = 1
+ ) AS group_member_count
+ ");
+
+ /*WHERE
+ {$this->tableName()}.id = core_group_member.group_id
AND
- {$cgm}.user_id = {$cp}.id
+ core_group_member.user_id = core_person.id
AND
- {$cp}.active = 1
- )
-
- AS group_member_count
- ");
- DB_DataObject::debugLevel();
-
+ core_person.active = 1
+ )*/
+
+// $this->whereAdd("{$this->tableName()}.id = core_group_member.group_id");
+// $this->whereAdd("core_group_member.user_id = core_person.id");
+// $this->whereAdd("core_person.active = 1");
/*$cgmDBObj->joinAdd($cpObj);