// 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());
}
}
-
-
-// $cp = DB_DataObject::Factory('core_person')->tableName();
-// $cgm = DB_DataObject::Factory('core_group_member')->tableName();
+ $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_group_member.group_id = core_group.id
- AND
- 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
- core_group_member.user_id = core_person.id
- AND
- 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);
- $this->joinAdd($cgmDBObj);
- DB_DataObject::debugLevel();*/
}
function toEventString() {
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;