// 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}%'");
$core_group = DB_DataObject::factory('core_group');
if($core_group->get('name', $q['_count_member_by_name'])){
- $roo->jdata($core_group->memberCount());
+ $roo->jok($core_group->memberCount());
}
}
+ if(!empty($q['_is_in_group'])){
+ $this->selectAdd("
+ COALESCE((
+ SELECT
+ COUNT(id)
+ FROM
+ core_group_member
+ WHERE
+ user_id = {$q['_is_in_group']}
+ AND
+ group_id = {$this->tableName()}.id
+ ), 0) AS is_in_group
+ ");
+ }
+
+
+ $cp = DB_DataObject::Factory('core_person')->tableName();
+ $cgm = DB_DataObject::Factory('core_group_member')->tableName();
+
+ $this->selectAdd("
+ (
+ 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
+ ");
+
}
function toEventString() {
$roo->jerr("missing group id");
}
- foreach(explode(',', $q['user_ids']) as $uid) {
+ print_R(explode(',', $q['user_ids']));exit;
+ foreach(explode(',', $q['user_ids']) as $uid) {
switch($q['_action']) {
case 'add':
$g->addMember($uid,$roo);
{
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
+ $gm->autoJoin();
+ $gm->whereAdd('join_user_id_id.active = 1');
+ //PDO_DAtaObject::DebugLevel(1);
return $gm->count();
}
{
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
+ $gm->autoJoin();
+ $gm->whereAdd('join_user_id_id.active = 1');
return $gm->fetchAll('user_id');
}
return $gm->count();
}
- function addMember($person,$roo)
+ function addMember($person,$roo = false)
{
- if ($this->name != "Empty Group") {
- //$this->jerr('Cannot the person into the empty group');
+ if ($this->name == "Empty Group") {
+ $roo->jerr('Cannot add the person into Empty Group');
}
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
// groups databse is hard coded to person.. so this should not be used for other tables.????
$p = DB_Dataobject::factory( 'core_person' );
-
-
$p->whereAdd('id IN ('. implode(',', $ids) .')');
$p->active = 1;
function initGroups()
{
-
+
$g = DB_DataObject::factory($this->tableName());
$g->type = 0;
$g->name = 'Administrators';
foreach($data as $gi) {
$g = DB_DataObject::factory($this->tableName());
+
+ $o = false;
+
+ if($g->get('name', $gi['name'])){
+ $o = clone($g);
+ }
+
+ $display_name = (isset($gi['display_name'])) ? $gi['display_name'] : '';
+
+ unset($gi['display_name']);
+
$g->setFrom($gi);
-
- if(!$g->find(true)){
- $g->insert();
+
+ if(empty($o) || empty($o->display_name)){
+ $g->display_name = $display_name;
}
+
+ (empty($o)) ? $g->insert() : $g->update($o);
if(count($g->members()) || empty($gi['members'])){
continue;