mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
464 lines
12 KiB
PHP
464 lines
12 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2013 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
*/
|
|
|
|
|
|
if (!defined('e107_INIT')) { exit; }
|
|
|
|
class page_sitelink // include plugin-folder in the name.
|
|
{
|
|
private $chapterSef = array();
|
|
private $chapterParent = array();
|
|
private $chapterName = array();
|
|
|
|
function __construct()
|
|
{
|
|
$sql = e107::getDb();
|
|
|
|
$books = $sql->retrieve("SELECT chapter_id,chapter_name,chapter_sef,chapter_parent FROM #page_chapters ORDER BY chapter_id ASC" , true);
|
|
|
|
foreach($books as $row)
|
|
{
|
|
$id = $row['chapter_id'];
|
|
$this->chapterSef[$id] = $row['chapter_sef'];
|
|
$this->chapterParent[$id] = $row['chapter_parent'];
|
|
$this->chapterName[$id] = $row['chapter_name'];
|
|
}
|
|
|
|
|
|
}
|
|
|
|
private function getName($chapter)
|
|
{
|
|
return varset($this->chapterName[$chapter], null);
|
|
}
|
|
|
|
|
|
private function getSef($chapter)
|
|
{
|
|
return vartrue($this->chapterSef[$chapter],'--sef-not-assigned--');
|
|
}
|
|
|
|
private function getParent($chapter)
|
|
{
|
|
return varset($this->chapterParent[$chapter], false);
|
|
}
|
|
|
|
|
|
function config()
|
|
{
|
|
$links = array();
|
|
$sql = e107::getDb();
|
|
|
|
$links[] = array(
|
|
'name' => "All Books",
|
|
'function' => "bookNav",
|
|
'description' => "A list of all books"
|
|
);
|
|
|
|
/* // TODO - get these working.
|
|
$links[] = array(
|
|
'name' => "All Books & chapters",
|
|
'function' => "bookNavChapters",
|
|
'description' => "A list of all books and their chapters"
|
|
);
|
|
|
|
$links[] = array(
|
|
'name' => "All Books, Chapters & Pages",
|
|
'function' => "bookNavChaptersPages",
|
|
'description' => "A list of all books, chapters and pages"
|
|
);
|
|
*/
|
|
$books = $sql->retrieve("SELECT * FROM #page_chapters WHERE chapter_parent =0 ORDER BY chapter_order ASC" , true);
|
|
|
|
foreach($books as $row)
|
|
{
|
|
$links[] = array(
|
|
'name' => "All Chapters from ".$row['chapter_name'],
|
|
'function' => "chapterNav",
|
|
'parm' => $row['chapter_id'],
|
|
'description' => "A list of all chapters from the book ".$row['chapter_name']
|
|
);
|
|
|
|
$links[] = array(
|
|
'name' => "All Chapters & Pages from ".$row['chapter_name'],
|
|
'function' => "chapterNavPages",
|
|
'parm' => $row['chapter_id'],
|
|
'description' => "A list of all chapters and pages from the book ".$row['chapter_name']
|
|
);
|
|
}
|
|
|
|
$chaps = $sql->retrieve("SELECT * FROM #page_chapters WHERE chapter_parent !=0 ORDER BY chapter_order ASC" , true);
|
|
|
|
foreach($chaps as $row)
|
|
{
|
|
$links[] = array(
|
|
'name' => "All Pages from ".$row['chapter_name'],
|
|
'function' => "pagesFromChapter",
|
|
'parm' => $row['chapter_id'],
|
|
'description' => "A list of all pages from the chapter ".$row['chapter_name']
|
|
);
|
|
}
|
|
|
|
$links[] = array(
|
|
'name' => "All Pages",
|
|
'function' => "pageList",
|
|
'parm' => "",
|
|
'description' => "A list of all pages"
|
|
);
|
|
|
|
return $links;
|
|
}
|
|
|
|
/**
|
|
* Return a tree of all books and their chapters.
|
|
*/
|
|
public function bookNav($book=0)
|
|
{
|
|
$parm = array('book'=>$book);
|
|
return $this->pageNav($parm);
|
|
}
|
|
|
|
|
|
//TODO
|
|
public function bookNavChapters($book=0)
|
|
{
|
|
$parm = array('book'=>$book, 'chapters'=>true);
|
|
return $this->pageNav($parm);
|
|
}
|
|
|
|
|
|
//TODO
|
|
public function bookNavChaptersPages($book=0)
|
|
{
|
|
$parm = array('book'=>$book, 'chapters'=>true, 'pages'=>true);
|
|
return $this->pageNav($parm);
|
|
}
|
|
|
|
|
|
|
|
public function chapterNavPages($id)
|
|
{
|
|
return $this->chapterNav($id, true);
|
|
}
|
|
|
|
public function pagesFromChapter($id)
|
|
{
|
|
return $this->pageList($id);
|
|
}
|
|
|
|
|
|
public function pageList($parm)
|
|
{
|
|
$sql = e107::getDb();
|
|
$arr = array();
|
|
|
|
|
|
if(!empty($parm))
|
|
{
|
|
$query = "SELECT * FROM `#page` WHERE page_class IN (".USERCLASS_LIST.") AND page_chapter = ".intval($parm)." ORDER BY page_order ASC" ;
|
|
}
|
|
else
|
|
{
|
|
$query = "SELECT * FROM `#page` WHERE page_class IN (".USERCLASS_LIST.") ORDER BY page_order ASC" ;
|
|
}
|
|
|
|
$pages = $sql->retrieve($query, true);
|
|
|
|
foreach($pages as $row)
|
|
{
|
|
$chapter_parent = $this->getParent($row['page_chapter']);
|
|
|
|
$row['book_sef'] = $this->getSef($chapter_parent);
|
|
|
|
$row['chapter_sef'] = $this->getSef($row['page_chapter']);
|
|
|
|
//if(!vartrue($row['chapter_sef']))
|
|
//{
|
|
// $row['chapter_sef'] = '--sef-not-assigned--';
|
|
// }
|
|
|
|
$arr[] = $this->pageArray($row);
|
|
|
|
}
|
|
|
|
return $arr;
|
|
|
|
}
|
|
|
|
private function pageArray($row,$options=array())
|
|
{
|
|
|
|
if(!empty($options['name']))
|
|
{
|
|
$name = $options['name'];
|
|
$link_name = $row[$name];
|
|
}
|
|
else
|
|
{
|
|
$link_name = !empty($row['page_title']) ? $row['page_title'] : 'No title'; // FIXME lan
|
|
}
|
|
|
|
return array(
|
|
'link_id' => $row['page_id'],
|
|
'link_name' => $link_name,
|
|
'link_url' => e107::getUrl()->create('page/view', $row, array('allow' => 'page_sef,page_title,page_id,chapter_sef,book_sef')),
|
|
'link_description' => '',
|
|
'link_button' => (!empty($options['icon']) && $options['icon'] === 'menu_image') ? $row['menu_image'] : '',
|
|
'link_category' => '',
|
|
'link_order' => $row['page_order'],
|
|
'link_parent' => $row['page_chapter'],
|
|
'link_open' => '',
|
|
'link_class' => intval($row['page_class']),
|
|
'link_active' => (isset($options['cpage']) && $row['page_id'] == $options['cpage']),
|
|
'link_identifier' => 'page-nav-'.intval($row['page_id']) // used for css id.
|
|
|
|
);
|
|
|
|
|
|
}
|
|
|
|
/**
|
|
* Return a list of all chapters from a sepcific book.
|
|
*/
|
|
public function chapterNav($book, $loadPages=false)
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
|
|
|
|
|
|
|
|
|
|
if($sql->select("page_chapters", "*", "chapter_parent = ".intval($book)." AND chapter_visibility IN (".USERCLASS_LIST.") ORDER BY chapter_order ASC "))
|
|
{
|
|
$chapters = array();
|
|
$ids = array();
|
|
|
|
while($row = $sql->fetch())
|
|
{
|
|
$ids[] = $row['chapter_id'];
|
|
$id = $row['chapter_id'];
|
|
|
|
$sef = $row;
|
|
$sef['chapter_sef'] = $this->getSef($row['chapter_id']);
|
|
$sef['book_sef'] = $this->getSef($row['chapter_parent']);
|
|
|
|
$chapters[$id] = array(
|
|
'link_name' => $tp->toHTML($row['chapter_name'],'','TITLE'),
|
|
'link_url' => e107::getUrl()->create('page/chapter/index', $sef), // 'page.php?ch='.$row['chapter_id'],
|
|
'link_description' => '',
|
|
'link_button' => $row['chapter_icon'],
|
|
'link_category' => '',
|
|
'link_order' => '',
|
|
'link_parent' => $row['chapter_parent'],
|
|
'link_open' => '',
|
|
'link_class' => 0,
|
|
'link_sub' => array(),
|
|
'link_identifier' => 'page-nav-'.intval($row['chapter_id']) // used for css id.
|
|
);
|
|
|
|
}
|
|
|
|
|
|
if($loadPages === true)
|
|
{
|
|
$pages = $sql->retrieve("SELECT * FROM #page WHERE page_title !='' AND page_chapter IN (".implode(",",$ids).") AND page_class IN (".USERCLASS_LIST.") ORDER BY page_order", true);
|
|
foreach($pages as $row)
|
|
{
|
|
$chap = $row['page_chapter'];
|
|
$chapters[$chap]['link_sub'][] = $this->pageArray($row);
|
|
|
|
}
|
|
|
|
// e107::getDebug()->log($pages);
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return $chapters;
|
|
|
|
}
|
|
}
|
|
|
|
function pageNav($parm=null)
|
|
{
|
|
$frm = e107::getForm();
|
|
$options = array();
|
|
|
|
if(!empty($parm))
|
|
{
|
|
if(is_string($parm))
|
|
{
|
|
parse_str($parm,$options);
|
|
}
|
|
elseif(is_array($parm))
|
|
{
|
|
$options = $parm;
|
|
}
|
|
}
|
|
|
|
$sql = e107::getDb();
|
|
$sublinks = array();
|
|
$arr = array();
|
|
|
|
// map current when in auto mode
|
|
if(!empty($options['auto']))
|
|
{
|
|
// current book found, top book not set
|
|
if(!empty($options['cbook']) && empty($options['book']))
|
|
{
|
|
$options['book'] = $options['cbook'];
|
|
}
|
|
|
|
// current chapter found, top chapter not set
|
|
if(!empty($options['cchapter']) && empty($options['chapter']))
|
|
{
|
|
$options['chapter'] = $options['cchapter'];
|
|
}
|
|
|
|
// current chapter found, top chapter not set
|
|
if(!empty($options['cpage']) && empty($options['page']))
|
|
{
|
|
$options['page'] = $options['cpage'];
|
|
}
|
|
}
|
|
|
|
// find the chapter if required
|
|
if(!empty($options['page']) && empty($options['chapter']))
|
|
{
|
|
$options['chapter'] = $sql->retrieve('page', 'page_chapter', 'page_id='.intval($options['page']));
|
|
}
|
|
|
|
$query = "SELECT * FROM #page WHERE ";
|
|
$q = array();
|
|
|
|
if(vartrue($options['chapter']))
|
|
{
|
|
$q[] = "page_title !='' AND page_chapter = ".intval($options['chapter']);
|
|
}
|
|
elseif(vartrue($options['book']))
|
|
{
|
|
$q[] = "page_title !='' && page_chapter IN (SELECT chapter_id FROM #page_chapters WHERE chapter_parent=".intval($options['book']).")";
|
|
}
|
|
// XXX discuss FIXED remove DB check, use default title - AND page_title !=''
|
|
$q[] = "page_class IN (".USERCLASS_LIST.")";
|
|
|
|
$query .= implode(' AND ', $q)." ORDER BY page_order";
|
|
|
|
$data = $sql->retrieve($query, true);
|
|
$_pdata = array();
|
|
/*
|
|
if(empty($data))
|
|
{
|
|
e107::getDebug()->log($query);
|
|
e107::getDebug()->dump($data);
|
|
}
|
|
*/
|
|
|
|
foreach($data as $row)
|
|
{
|
|
$pid = $row['page_chapter'];
|
|
|
|
$row['chapter_sef'] = $this->getSef($row['page_chapter']);
|
|
$book = $this->getParent($row['page_chapter']);
|
|
$row['book_sef'] = $this->getSef($book);
|
|
|
|
if(!vartrue($row['page_sef']))
|
|
{
|
|
$row['page_sef'] = '--sef-not-assigned--';
|
|
}
|
|
|
|
$sublinks[$pid][] = $_pdata[] = $this->pageArray($row,$options); /* array(
|
|
'link_id' => $row['page_id'],
|
|
'link_name' => $row['page_title'] ? $row['page_title'] : 'No title', // FIXME lan
|
|
'link_url' => e107::getUrl()->create('page/view', $row, array('allow' => 'page_sef,page_title,page_id,chapter_sef,book_sef')),
|
|
'link_description' => '',
|
|
'link_button' => $row['menu_image'],
|
|
'link_category' => '',
|
|
'link_order' => $row['page_order'],
|
|
'link_parent' => $row['page_chapter'],
|
|
'link_open' => '',
|
|
'link_class' => intval($row['page_class']),
|
|
'link_active' => (isset($options['cpage']) && $row['page_id'] == $options['cpage']),
|
|
'link_identifier' => 'page-nav-'.intval($row['page_id']) // used for css id.
|
|
|
|
);*/
|
|
}
|
|
|
|
$filter = "chapter_visibility IN (".USERCLASS_LIST.") " ;
|
|
|
|
if(!empty($options['chapter']))
|
|
{
|
|
$title = $sql->retrieve('page_chapters', 'chapter_name', 'chapter_id='.intval($options['chapter']).' AND chapter_visibility IN ('.USERCLASS_LIST.')' );
|
|
$outArray = array();
|
|
|
|
if(!$title)
|
|
{
|
|
return e107::getNav()->compile($_pdata, $outArray, $options['chapter']);
|
|
}
|
|
|
|
return array('title' => $title, 'body' => e107::getNav()->compile($_pdata, $outArray, $options['chapter']));
|
|
}
|
|
|
|
$parent = 0;
|
|
$title = false;
|
|
|
|
if(!empty($options['book']))
|
|
{
|
|
$filter = "chapter_parent = ".intval($options['book']);
|
|
$title = $this->getName($options['book']); // set the caption as main book title.
|
|
}
|
|
|
|
|
|
$books = $sql->retrieve("SELECT * FROM #page_chapters WHERE ".$filter." ORDER BY chapter_order ASC" , true);
|
|
foreach($books as $row)
|
|
{
|
|
$row['book_sef'] = $this->getSef($row['chapter_parent']);
|
|
|
|
if(empty($row['chapter_sef']))
|
|
{
|
|
$row['chapter_sef'] = '--sef-not-assigned--';
|
|
}
|
|
|
|
$arr[] = array(
|
|
'link_id' => $row['chapter_id'],
|
|
'link_name' => $row['chapter_name'],
|
|
'link_url' => ($row['chapter_parent'] == 0) ? e107::getUrl()->create('page/book/index', $row) : e107::getUrl()->create('page/chapter/index', $row), // ,'page.php?bk='.$row['chapter_id'] : 'page.php?ch='.$row['chapter_id'],
|
|
'link_description' => '',
|
|
'link_button' => $row['chapter_icon'],
|
|
'link_category' => '',
|
|
'link_order' => $row['chapter_order'],
|
|
'link_parent' => $row['chapter_parent'],
|
|
'link_open' => '',
|
|
'link_class' => 0,
|
|
'link_sub' => ((empty($options['book']) || !empty($options['pages'])) && empty($options['auto'])) ? varset($sublinks[$row['chapter_id']]) : false, //XXX always test with docs template in bootstrap before changing.
|
|
'link_active' => $row['chapter_parent'] == 0 ? isset($options['cbook']) && $options['cbook'] == $row['chapter_id'] : isset($options['cchapter']) && $options['cchapter'] == $row['chapter_id'],
|
|
'link_identifier' => 'page-nav-'.intval($row['chapter_id']) // used for css id.
|
|
);
|
|
|
|
}
|
|
/*
|
|
if(!empty($options['book']))
|
|
{
|
|
e107::getDebug()->dump($arr);
|
|
}*/
|
|
|
|
$outArray = array();
|
|
$parent = vartrue($options['book']) ? intval($options['book']) : 0;
|
|
|
|
$ret = e107::getNav()->compile($arr, $outArray, $parent);
|
|
|
|
if(!$title) return $ret;
|
|
return array('title' => $title, 'body' => $ret);
|
|
}
|
|
}
|