1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
<?php defined("SYSPATH") or die("No direct script access.");
/**
* Gallery - a web based photo album viewer and editor
* Copyright (C) 2000-2011 Bharat Mediratta
*
* 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., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
class Breadcrumb_Core {
public $title;
public $url;
public $first;
public $last;
static function instance($title, $url) {
return new Breadcrumb($title, $url);
}
public function __construct($title, $url) {
$this->title = $title;
$this->url = $url;
$this->first = false;
$this->last = false;
}
/**
* Return an array of Breadcrumb instances build from the parents of a given item.
* The first and last Breadcrumb instances will be marked first/last as appropriate.
* Each breadcrumb will have a ?show= query parameter that refers to the id of the next
* item in line.
*
* @return array Breadcrumb instances
*/
static function array_from_item_parents($item) {
if ($item->id == item::root()->id) {
return array();
}
$bc = array_merge($item->parents()->as_array(), array($item));
for ($i = 0; $i < count($bc) - 1; $i++) {
$bc[$i] = new Breadcrumb($bc[$i]->title, $bc[$i]->url("show={$bc[$i+1]->id}"));
}
$bc[$i] = new Breadcrumb($item->title, $item->url());
$bc[0]->set_first();
end($bc)->set_last();
return $bc;
}
public function set_first() {
$this->first = true;
return $this;
}
public function set_last() {
$this->last = true;
return $this;
}
}
|