browse.php 4.61 KB
<?php

/**
 * $Id$
 *
 * Copyright (c) 2005 Jam Warehouse http://www.jamwarehouse.com
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 * 
 * 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
 *
 * @version $Revision$
 * @author Brad Shuttleworth <brad@jamwarehouse.com>, Jam Warehouse (Pty) Ltd, South Africa
 */

// main library routines and defaults
require_once("../../../config/dmsDefaults.php");
require_once(KT_LIB_DIR . "/templating/templating.inc.php");
require_once(KT_LIB_DIR . "/templating/kt3template.inc.php");
require_once(KT_LIB_DIR . "/dispatcher.inc.php");
require_once(KT_LIB_DIR . "/util/ktutil.inc");
require_once(KT_LIB_DIR . "/browse/DocumentCollection.inc.php");
require_once(KT_LIB_DIR . "/browse/BrowseColumns.inc.php");
require_once(KT_LIB_DIR . "/browse/PartialQuery.inc.php");
require_once(KT_LIB_DIR . "/browse/browseutil.inc.php");

require_once(KT_LIB_DIR . "/foldermanagement/Folder.inc");

require_once(KT_LIB_DIR . "/widgets/portlet.inc.php");
require_once(KT_LIB_DIR . '/actions/folderaction.inc.php');
require_once(KT_DIR . '/plugins/ktcore/KTFolderActions.php');


$sectionName = "browse";

class BrowseDispatcher extends KTStandardDispatcher {

    
	var $sSection = "browse";
	var $browseType;

    function BrowseDispatcher() {
        $this->aBreadcrumbs = array(
            array('action' => 'browse', 'name' => _('Browse')),
        );
        return parent::KTStandardDispatcher();
    }
	
    function check() {
        // which folder.
        $in_folder_id = KTUtil::arrayGet($_REQUEST, "fFolderId", 1);
        $folder_id = (int) $in_folder_id; // conveniently, will be 0 if not possible.
        if ($folder_id == 0) {
            $folder_id = 1;
        }

        // here we need the folder object to do the breadcrumbs.
        $this->oFolder =& Folder::get($folder_id);
        if (PEAR::isError($this->oFolder)) {
           $this->oPage->addError(_("invalid folder"));
           $folder_id = 1;
           $this->oFolder =& Folder::get($folder_id);
        }
        return true;
    }

    function do_main() {
		$collection = new DocumentCollection;
		$this->browseType = "Folder"; 
		
		$collection->addColumn(new SelectionColumn("Browse Selection","selection"));
		$collection->addColumn(new TitleColumn("Test 1 (title)","title"));
		$collection->addColumn(new DateColumn(_("Created"),"created", "getCreatedDateTime"));
		$collection->addColumn(new DateColumn(_("Last Modified"),"modified", "getLastModifiedDate"));
		$collection->addColumn(new UserColumn(_('Creator'),'creator_id','getCreatorID'));
		
        $this->aBreadcrumbs = array_merge($this->aBreadcrumbs,
                KTBrowseUtil::breadcrumbsForFolder($this->oFolder));
		// setup the folderside add actions
		// FIXME do we want to use folder actions?
		$portlet = new KTActionPortlet(_("Folder Actions"));
		
		
		// FIXME make a FolderActionUtil ... is it necessary?
		
		$aActions = KTFolderActionUtil::getFolderActionsForFolder($this->oFolder, $this->oUser);
		
		$portlet->setActions($aActions,null);
		
		$this->oPage->addPortlet($portlet);
		
		$batchPage = (int) KTUtil::arrayGet($_REQUEST, "page", 0);
		$batchSize = 20;
		
		$resultURL = "?fFolderId=" . $this->oFolder->getId();
		$collection->setBatching($resultURL, $batchPage, $batchSize); 
		
		
		// ordering. (direction and column)
		$displayOrder = KTUtil::arrayGet($_REQUEST, 'sort_order', "asc");		
		if ($displayOrder !== "asc") { $displayOrder = "desc"; }
		$displayControl = KTUtil::arrayGet($_REQUEST, 'sort_on', "title");		
		
		
		$collection->setSorting($displayControl, $displayOrder);
		
		// add in the query object.
		$qObj = new BrowseQuery($this->oFolder->getId());
		$collection->setQueryObject($qObj);
		
		// breadcrumbs
		// FIXME handle breadcrumbs
		$collection->getResults();
		
		$oTemplating = new KTTemplating;
		$oTemplate = $oTemplating->loadTemplate("kt3/browse");
		$aTemplateData = array(
              "context" => $this,
			  "collection" => $collection,
		);
		return $oTemplate->render($aTemplateData);
	}   
}

$oDispatcher = new BrowseDispatcher();
$oDispatcher->dispatch();

?>