OEModule\OphCoMessaging\components\OphCoMessaging_API::getSentMessages PHP Method

getSentMessages() public method

Get sent messages.
public getSentMessages ( CWebUser $user = null ) : array
$user CWebUser
return array title and content for the widget
    public function getSentMessages($user = null)
    {
        if (is_null($user)) {
            $user = \Yii::app()->user;
        }
        $sort = new \CSort();
        $sort->attributes = array('priority' => array('asc' => 'urgent asc', 'desc' => 'urgent desc'), 'event_date' => array('asc' => 't.created_date asc', 'desc' => 't.created_date desc'), 'patient_name' => array('asc' => 'lower(contact.last_name) asc, lower(contact.first_name) asc', 'desc' => 'lower(contact.last_name) desc, lower(contact.first_name) desc'), 'hos_num' => array('asc' => 'patient.hos_num asc', 'desc' => 'patient.hos_num desc'), 'dob' => array('asc' => 'patient.dob asc', 'desc' => 'patient.dob desc'), 'user' => array('asc' => 'lower(for_the_attention_of_user.last_name) asc, lower(for_the_attention_of_user.first_name) asc', 'desc' => 'lower(for_the_attention_of_user.last_name) desc, lower(for_the_attention_of_user.first_name) desc'));
        $sort->defaultOrder = 'event_date desc';
        $from = \Yii::app()->request->getQuery('OphCoMessaging_sent_from', '');
        $to = \Yii::app()->request->getQuery('OphCoMessaging_sent_to', '');
        $params = array(':uid' => $user->id);
        $criteria = new \CDbCriteria();
        $criteria->select = array('*');
        $criteria->addCondition('t.created_user_id = :uid');
        $criteria->with = array('event', 'for_the_attention_of_user', 'message_type', 'event.episode', 'event.episode.patient', 'event.episode.patient.contact');
        $criteria->together = true;
        if ($from) {
            $criteria->addCondition('DATE(t.created_date) >= :from');
            $params[':from'] = \Helper::convertNHS2MySQL($from);
        }
        if ($to) {
            $criteria->addCondition('DATE(t.created_date) <= :to');
            $params[':to'] = \Helper::convertNHS2MySQL($to);
        }
        $criteria->addCondition('event.deleted = 0');
        $criteria->addCondition('episode.deleted = 0');
        $criteria->params = $params;
        $dataProvider = new \CActiveDataProvider('OEModule\\OphCoMessaging\\models\\Element_OphCoMessaging_Message', array('sort' => $sort, 'criteria' => $criteria, 'pagination' => array('pageSize' => 10)));
        $messages = Element_OphCoMessaging_Message::model()->findAll($criteria);
        \Yii::app()->getAssetManager()->registerCssFile('module.css', 'application.modules.OphCoMessaging.assets.css');
        $inbox_view = \Yii::app()->controller->renderPartial('OphCoMessaging.views.sent.grid', array('messages' => $messages, 'dataProvider' => $dataProvider), true);
        return array('title' => 'Sent Messages', 'content' => $inbox_view, 'options' => array('container-id' => \Yii::app()->user->id . '-sent-container', 'js-toggle-open' => \Yii::app()->request->cookies->contains(\Yii::app()->user->id . '-sent-container-state') ? (bool) \Yii::app()->request->cookies[\Yii::app()->user->id . '-sent-container-state']->value : false));
    }