mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
Merge pull request #511 from tigrang/crumb-list-opt
Moving duplicate logic to a new method
This commit is contained in:
commit
e5205a8dcc
1 changed files with 26 additions and 28 deletions
|
@ -684,21 +684,8 @@ class HtmlHelper extends AppHelper {
|
|||
public function getCrumbs($separator = '»', $startText = false) {
|
||||
if (!empty($this->_crumbs)) {
|
||||
$out = array();
|
||||
if ($startText) {
|
||||
if (!is_array($startText)) {
|
||||
$startText = array(
|
||||
'url' => '/',
|
||||
'text' => $startText
|
||||
);
|
||||
}
|
||||
$startText += array('url' => '/', 'text' => __('Home'));
|
||||
list($url, $text) = array($startText['url'], $startText['text']);
|
||||
unset($startText['url'], $startText['text']);
|
||||
|
||||
$out[] = $this->link($text, $url, $startText);
|
||||
}
|
||||
|
||||
foreach ($this->_crumbs as $crumb) {
|
||||
$crumbs = $this->_prepareCrumbs($startText);
|
||||
foreach ($crumbs as $crumb) {
|
||||
if (!empty($crumb[1])) {
|
||||
$out[] = $this->link($crumb[0], $crumb[1], $crumb[2]);
|
||||
} else {
|
||||
|
@ -727,19 +714,7 @@ class HtmlHelper extends AppHelper {
|
|||
public function getCrumbList($options = array(), $startText = false) {
|
||||
if (!empty($this->_crumbs)) {
|
||||
$result = '';
|
||||
$crumbs = $this->_crumbs;
|
||||
if ($startText) {
|
||||
if (!is_array($startText)) {
|
||||
$startText = array(
|
||||
'url' => '/',
|
||||
'text' => $startText
|
||||
);
|
||||
}
|
||||
$startText += array('url' => '/', 'text' => __('Home'));
|
||||
list($url, $text) = array($startText['url'], $startText['text']);
|
||||
unset($startText['url'], $startText['text']);
|
||||
array_unshift($crumbs, array($text, $url, $startText));
|
||||
}
|
||||
$crumbs = $this->_prepareCrumbs($startText);
|
||||
$crumbCount = count($crumbs);
|
||||
$ulOptions = $options;
|
||||
foreach ($crumbs as $which => $crumb) {
|
||||
|
@ -762,6 +737,29 @@ class HtmlHelper extends AppHelper {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepends startText to crumbs array if set
|
||||
*
|
||||
* @param $startText
|
||||
* @return array Crumb list including startText (if provided)
|
||||
*/
|
||||
protected function _prepareCrumbs($startText) {
|
||||
$crumbs = $this->_crumbs;
|
||||
if ($startText) {
|
||||
if (!is_array($startText)) {
|
||||
$startText = array(
|
||||
'url' => '/',
|
||||
'text' => $startText
|
||||
);
|
||||
}
|
||||
$startText += array('url' => '/', 'text' => __('Home'));
|
||||
list($url, $text) = array($startText['url'], $startText['text']);
|
||||
unset($startText['url'], $startText['text']);
|
||||
array_unshift($crumbs, array($text, $url, $startText));
|
||||
}
|
||||
return $crumbs;
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates a formatted IMG element.
|
||||
*
|
||||
|
|
Loading…
Add table
Reference in a new issue