Location: PHPKode > projects > VuFind > vufind-1.0.1/web/services/MyResearch/lib/FavoriteHandler.php
<?php
/**
 *
 * Copyright (C) Villanova University 2010.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2,
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */
require_once 'services/MyResearch/lib/Resource.php';
require_once 'sys/Pager.php';

/**
 * FavoriteHandler Class
 *
 * This class contains shared logic for displaying lists of favorites (based on
 * earlier logic duplicated between the MyResearch/Home and MyResearch/MyList
 * actions).
 *
 * @author      Demian Katz <hide@address.com>
 * @access      public
 */
class FavoriteHandler
{
    private $favorites;
    private $user;
    private $listId;
    private $allowEdit;
    private $ids = array();

    /**
     * Constructor.
     *
     * @access  public
     * @param   array   $favorites  Array of Resource objects.
     * @param   object  $user       User object owning tag/note metadata.
     * @param   int     $listId     ID of list containing desired tags/notes (or 
     *                              null to show tags/notes from all user's lists).
     * @param   bool    $allowEdit  Should we display edit controls?
     */
    public function __construct($favorites, $user, $listId = null, $allowEdit = true)
    {
        $this->favorites = $favorites;
        $this->user = $user;
        $this->listId = $listId;
        $this->allowEdit = $allowEdit;
        
        // Process the IDs found in the favorites (sort by source):
        if (is_array($favorites)) {
            foreach($favorites as $current) {
                $id = $current->record_id;
                if (!empty($id)) {
                    $source = $current->source;
                    if (!isset($this->ids[$source])) {
                        $this->ids[$source] = array();
                    }
                    $this->ids[$source][] = $id;
                }
            }
        }
    }

    /**
     * Assign all necessary values to the interface.
     *
     * @access  public
     */
    public function assign()
    {
        global $interface;

        // Initialise from the current search globals
        $searchObject = SearchObjectFactory::initSearchObject();
        $searchObject->init();
        $interface->assign('sortList', $searchObject->getSortList());

        // Retrieve records from index (currently, only Solr IDs supported):
        if (array_key_exists('VuFind', $this->ids) && 
            count($this->ids['VuFind']) > 0) {
            $searchObject->setQueryIDs($this->ids['VuFind']);
            $result = $searchObject->processSearch();
            $resourceList = $searchObject->getResultListHTML($this->user,
                $this->listId, $this->allowEdit);
            $interface->assign('resourceList', $resourceList);
        }

        // Set up paging of list contents:
        $summary = $searchObject->getResultSummary();
        $interface->assign('recordCount', $summary['resultTotal']);
        $interface->assign('recordStart', $summary['startRecord']);
        $interface->assign('recordEnd',   $summary['endRecord']);

        $link = $searchObject->renderLinkPageTemplate();
        $options = array('totalItems' => $summary['resultTotal'],
                         'perPage' => $summary['perPage'],
                         'fileName' => $link);
        $pager = new VuFindPager($options);
        $interface->assign('pageLinks', $pager->getLinks());
    }
}

?>
Return current item: VuFind