mirror of
https://github.com/suk-ws/ph-Bookshelf.git
synced 2025-01-18 23:12:23 +08:00
完成了请求链接解析和当前 book 的目录生成
- 基础的请求链接解析实现 - 当前链接解析将第一个参数(首目录)视为 bookId,剩余视为 pageId - 即不支持 bookId中包含“/” - 同时实现了 books 的 active 判定 - 实现了通过 ID 进行查询容器中的 Book 或者 Page 的功能 - 实现了通过 Book对象 获取对应的 BookContented 对象 - 实现了 BookContented 的目录表生成 - 同时也有 active 判定
This commit is contained in:
parent
9bb1dd1a75
commit
6a5b4937c9
@ -1,6 +1,6 @@
|
||||
const WITH_SUMMARY_CLASS = "with-summary"
|
||||
|
||||
var bookRoot;
|
||||
let bookRoot;
|
||||
|
||||
function summaryOnOrOff () {
|
||||
|
||||
|
46
index.php
46
index.php
@ -6,9 +6,32 @@ require_once "./src/Data/PageMeta.php";
|
||||
try {
|
||||
|
||||
SiteMeta::load();
|
||||
PageMeta::$book = SiteMeta::getBookshelf()->getRootBook();
|
||||
PageMeta::$page = PageMeta::$book->getChilds()->getChilds()[0];
|
||||
PageMeta::$isMainPage = true;
|
||||
|
||||
// 格式化所给链接,并将链接转化为路径字符串数组
|
||||
$tmp = $_GET['p'];
|
||||
if (strlen($tmp) > 0 && $tmp[strlen($tmp) - 1] === '/')
|
||||
$tmp = substr($tmp, 0, -1);
|
||||
$uri = explode("/", $tmp, 2);
|
||||
|
||||
if (sizeof($uri) > 0 && $uri[0] != null) {
|
||||
// 非主页面,判定当前定义的 book
|
||||
$tmp = SiteMeta::getBookshelf()->getBook($uri[0]);
|
||||
if ($tmp == null) throw new Exception("Book required \"$uri[0]\" not found!");
|
||||
PageMeta::$book = $tmp->getContentedNode();
|
||||
// 判定当前页面
|
||||
if (sizeof($uri) > 1 && $uri[1] != null) {
|
||||
$tmp = PageMeta::$book->getPage($uri[1]);
|
||||
if ($tmp == null) throw new Exception("Page required \"$uri[1]\" not found on book \"$uri[0]\"!");
|
||||
PageMeta::$page = $tmp;
|
||||
} else {
|
||||
PageMeta::$page = PageMeta::$book->getChilds()->getChilds()[0];
|
||||
}
|
||||
} else {
|
||||
// 主页面
|
||||
PageMeta::$book = SiteMeta::getBookshelf()->getRootBook();
|
||||
PageMeta::$page = PageMeta::$book->getChilds()->getChilds()[0];
|
||||
PageMeta::$isMainPage = true;
|
||||
}
|
||||
|
||||
require "./template/header.php";
|
||||
|
||||
@ -21,22 +44,7 @@ try {
|
||||
</ul>
|
||||
</div>
|
||||
<nav role="navigation">
|
||||
<ul class="summary">
|
||||
<?= SiteMeta::getBookshelf()->getHtml(); ?>
|
||||
<li class="divider"></li>
|
||||
<li class="chapter active" data-level="1.1" data-path="./"><a href="./">占位主页面</a></li>
|
||||
<li class="chapter " data-level="1.2" data-path="api/">
|
||||
<a href="#">占位章节</a>
|
||||
<ul class="articles">
|
||||
<li class="chapter " data-level="1.2.1" data-path="api/color.html"><a href="chp/page.html">占位页面</a></li>
|
||||
<li class="chapter " data-level="1.2.2" data-path="api/suka-talk.html"><a href="chp/page-other.html">另一个占位页面</a></li>
|
||||
</ul>
|
||||
</li>
|
||||
<li class="chapter " data-level="1.3" data-path="srv-dev.html"><a href="backnote.html">占位后记</a></li>
|
||||
<li class="divider"></li>
|
||||
<li><a href="https://github.com/Eyre-S/ph-Bookshelf" target="blank" class="gitbook-link">Generated with ph-Bookshelf</a></li>
|
||||
<li><a href="https://www.gitbook.com" target="blank" class="gitbook-link">Front-End by GitBook</a></li>
|
||||
</ul>
|
||||
<?= SiteMeta::getBookshelf()->getHtml(); ?>
|
||||
</nav>
|
||||
</div>
|
||||
<div class="book-body">
|
||||
|
@ -7,7 +7,7 @@ class PageMeta {
|
||||
|
||||
public static BookContented $book;
|
||||
public static Page $page;
|
||||
public static bool $isMainPage;
|
||||
public static bool $isMainPage = false;
|
||||
|
||||
public static function getPageTitle (): string {
|
||||
return self::$page->getName()." - ".self::$book->getName();
|
||||
|
@ -1,6 +1,7 @@
|
||||
<?php
|
||||
|
||||
require_once "./src/Element/BookCollection.php";
|
||||
require_once "./src/Element/BookContent/BookContented.php";
|
||||
|
||||
class Book {
|
||||
|
||||
@ -53,7 +54,14 @@ class Book {
|
||||
}
|
||||
|
||||
public function getHtml (): string {
|
||||
return "<li class='link'><a class='link' href='$this->id'>$this->name</a></li>";
|
||||
return "<li class='link" . (PageMeta::$book->getId()==$this->id?" active":"") . "'><a class='link' href='/$this->id'>$this->name</a></li>";
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws Exception
|
||||
*/
|
||||
public function getContentedNode (): BookContented {
|
||||
return BookContented::parseString(file_get_contents("./data/$this->id/book.xml"));
|
||||
}
|
||||
|
||||
}
|
@ -72,7 +72,7 @@ class BookCollection {
|
||||
|
||||
public function getHtml (): string {
|
||||
$str = "";
|
||||
if ($this->name != self::ROOT) $str .= "<li><a class='book-collection' href='#'>$this->name</a><ul class='book-collection'>";
|
||||
if ($this->name != self::ROOT) $str .= "<li><a class='book-collection' href='#'>$this->name</a><ul class='book-collection summary'>";
|
||||
foreach ($this->array as $node) {
|
||||
$str .= $node->getHtml();
|
||||
}
|
||||
@ -80,4 +80,19 @@ class BookCollection {
|
||||
return $str;
|
||||
}
|
||||
|
||||
public function getBook (string $id): ?Book {
|
||||
|
||||
foreach ($this->array as $node) {
|
||||
if ($node instanceof Book && $node->getId() == $id)
|
||||
return $node;
|
||||
else if ($node instanceof BookCollection) {
|
||||
$got = $node->getBook($id);
|
||||
if ($got != null) return $got;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -63,4 +63,12 @@ class BookContented {
|
||||
return $this->childs;
|
||||
}
|
||||
|
||||
public function getSummaryHtml (): string {
|
||||
return $this->childs->getSummaryHtml();
|
||||
}
|
||||
|
||||
public function getPage (string $id): Page {
|
||||
return $this->childs->getPage($id);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -64,4 +64,29 @@ class Chapter {
|
||||
return $this->parent;
|
||||
}
|
||||
|
||||
public function getSummaryHtml (): string {
|
||||
$str = "";
|
||||
if ($this->parent != null) $str .= "<li class='chapter'><a class='page-chapter' href='#'>$this->name</a><ul class='page-chapter summary'>";
|
||||
foreach ($this->childs as $node) {
|
||||
$str .= $node->getSummaryHtml();
|
||||
}
|
||||
if ($this->parent != null) $str .= "</ul></li>";
|
||||
return $str;
|
||||
}
|
||||
|
||||
public function getPage (string $id): ?Page {
|
||||
|
||||
foreach ($this->childs as $node) {
|
||||
if ($node instanceof Page && $node->getId() == $id)
|
||||
return $node;
|
||||
else if ($node instanceof Chapter) {
|
||||
$got = $node->getPage($id);
|
||||
if ($got != null) return $got;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -71,4 +71,17 @@ class Page {
|
||||
return $this->parent;
|
||||
}
|
||||
|
||||
public function getSummaryHtml (): string {
|
||||
$str = "<li class='page-contented chapter" . (PageMeta::$page->getId()==$this->id?" active":"") . "'><a class='page-contented' href='/" . (PageMeta::$page->getId()==$this->id?"#":(PageMeta::$book->getId()."/".$this->id)) . "'>$this->name</a>";
|
||||
if (sizeof($this->segues) > 0) {
|
||||
$str .= "<ul class='page-contented summary'>";
|
||||
foreach ($this->segues as $node) {
|
||||
$str .= $node->getSummaryHtml();
|
||||
}
|
||||
$str .= "</ul>";
|
||||
}
|
||||
$str .= "</li>";
|
||||
return $str;
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -49,4 +49,8 @@ class Segment {
|
||||
return $this->parent;
|
||||
}
|
||||
|
||||
public function getSummaryHtml (): string {
|
||||
return "<li class='page-segment chapter'><a href='/" . (PageMeta::$page->getId()==$this->parent->getId()?"":PageMeta::$book->getId()."/".$this->parent->getId()."") . "#$this->id'>$this->name</a></li>";
|
||||
}
|
||||
|
||||
}
|
@ -75,9 +75,15 @@ class Bookshelf {
|
||||
$str .= $this->links->getHtml();
|
||||
$str .= "<li class='divider'></li>";
|
||||
$str .= $this->books->getHtml();
|
||||
$str .= "<li class='divider'></li>";
|
||||
$str .= PageMeta::$book->getSummaryHtml();
|
||||
$str .= "<li class='divider'></li><li><a href='https://github.com/Eyre-S/ph-Bookshelf' target='blank' class='gitbook-link'>Generated with ph-Bookshelf</a></li><li><a href='https://www.gitbook.com' target='blank' class='gitbook-link'>Front-End by GitBook</a></li>";
|
||||
$str .= "</ul>";
|
||||
// TODO books list
|
||||
return $str;
|
||||
}
|
||||
|
||||
public function getBook (string $id): ?Book {
|
||||
return $this->books->getBook($id);
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user