// group types??
function applyFilters($q, $au, $roo)
{
+
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());
}
}
-
-
+
+ if(!empty($q['_with_membership_user'])){
+ $q['_with_membership_user'] = 1*$q['_with_membership_user'];
+ $this->selectAdd("
+ COALESCE(
+ (SELECT id from core_group_member
+ WHERE
+ user_id = {$q['_with_membership_user']}
+ AND
+ group_id = {$this->tableName()}.id
+ LIMIT 1
+ ),0) as group_membership_user_id
+ ");
+ }
+
$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
${cp}.id = {$cgm}.user_id
WHERE
foreach($data as $gi) {
$g = DB_DataObject::factory($this->tableName());
+
+ $o = false;
+
+ if($g->get('name', $gi['name'])){
+ $o = clone($g);
+ }
+
$g->setFrom($gi);
if(!$g->find(true)){