Skip to content

shoesforindustry/kirby-plugins-uninextprev

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 

Repository files navigation

uniNextPrev Plugin

What is it?

The uniNextPrev Kirby CMS plugin provides variables with links and page titles for next/prev pages and can move through the site, up and down, through parent/children/grandchildren and also seamlessly moves through pagination (e.g. articles index)... if you set it. So a sort of universal next / prev & hence the name.

Although it works in Kirby2, I'm sure it could be written in a much better way, I just needed it for a project and was in a hurry. It's not had a huge amount of testing so beware and we're only posting here in response to a request on the Kirby Forum.

Warning

It only works at the parent/child/grandchild menu levels - it will fail with ugly errors if you try and go deeper! Four levels is probably too deep for a site anyway - but you have been warned - dragons.

Installation

Put the uninextprev folder in /site/plugins or use the Kirby CLI. To install using the Kirby CLI, from the command line in your project folder:

Install the plugin:

kirby plugin:install shoesforindustry/kirby-plugins-uninextprev

Update the plugin:

kirby plugin:update shoesforindustry/kirby-plugins-uninextprev

How to use it?

Basic

In your template add:

<?php
//Call uniNextPrev plugin
$uniNextPrev = uninextprev(); 
?>

With pagination

If your page has pagination (e.g. articles index), you should call it with that pagination. (If you don't set pagination it will ignore it and leave a big hole in your next / previous.)

Obviously you can only call this after you have created the pagination.

<?php
//Call uniNextPrev plugin with articles pagination
$uniNextPrev = uninextprev(array('pagination' => $articles->pagination())); 
?>

Using in a template

After you have called uninextprev() the plugin creates some variables which you can use in your template.

Note: These variables maybe empty so you should check before using!

  • nextPageURL - accessible through $uniNextPrev['nextPageURL']
  • nextPageTitle - accessible through $uniNextPrev['nextPageTitle']
  • nextPageUID - accessible through $uniNextPrev['nextPageUID']
  • prevPageURL - accessible through $uniNextPrev['prevPageURL']
  • prevPageTitle - accessible through $uniNextPrev['prevPageTitle']
  • prevPageUID - accessible through $uniNextPrev['prevPageUID']

Using in snippets (called from your template)

After you have called the uninextprev() plugin you can also use the plugin variables in snippets.

Call in a header snippet

Perhaps for 'head/rel' links e.g.

<link rel="next" title="Page title" href="http://...."/>
//Call header snippet with uniNextPrev plugin variables
snippet('header', array(
	'nextPageURL' => $uniNextPrev['nextPageURL'],
	'nextPageTitle' => $uniNextPrev['nextPageTitle'],
	'prevPageURL' => $uniNextPrev['prevPageURL'],
	'prevPageTitle' => $uniNextPrev['prevPageTitle']
));

In your header snippet use with something like (check to see if set and not blank!):

<?php if(isset($nextPageURL) AND $nextPageURL<>''): ?>
<link rel="next" title="<?php echo $nextPageTitle ?>" href="<?php echo $nextPageURL ?>"/>
<?php endif?>

Call in a footer snippet

Or in your <footer> with nav links e.g.

<a href="http://..." rel="next" title="Page title ->">Next ></a>
​````

​```php
//Call footer snippet with uniNextPrev plugin variables
snippet('footer', array(
	'nextPageURL' => $uniNextPrev['nextPageURL'],
	'nextPageTitle' => $uniNextPrev['nextPageTitle'],
	'prevPageURL' => $uniNextPrev['prevPageURL'],
	'prevPageTitle' => $uniNextPrev['prevPageTitle']
));

In your footer snippet use with something like (check to see if set!):

<?php if(isset($nextPageURL) AND $nextPageURL<>''): ?>
<a href="<?php echo $nextPageURL ?>" rel="next" title="<?php echo $nextPageTitle ?>">Next (<?php echo $nextPageTitle ?>)-></a>
<?php endif?>

Ignoring index page children

You can set a comma separated, quoted list of page uid's for which you want to ignore the children of in your next/prev. Maybe because you have an index page & detail pages, but only want to show the index and not the details.

In your config.php.

/*---------------------------------------
Set 'ignore_children; for uniNextPrev Plugin
-----------------------------------------
Set a comma separated quoted list of page uid's for which you want to ignore the children of in this plugin. Maybe because you have an index page & detail pages, but only want to show the index and not the details.
*/
// Here we are ignoring the children (details pages) of 'press' (index page)
c::set('uniNextPrev_ignore_children',array('press'));

Demo

You can see it in action on Susan Hall's website. Note you can page through the site using the buttons at the bottom of the page.

  1. You can move backwards & forwards down & up through levels (parent/children e.g. about/privacy).
  2. You also can page through an article index and then through the actual details pages (articles)
  3. Or just the index (press) skipping the detail pages (details pages are still findable with search).
  4. It also works with Tag index pages and search indexes.
  5. It is also used in the header in rel links for next & previous.

We set this is a particular way, for the flow through the site, but you can do it how you please.

Notes

In the demo, we don't call 'prev' on the first page or 'next' on the last, you could probably fix this ;-)

e.g. for first page/template:

snippet('footer', array(
	'nextPageURL' => $uniNextPrev['nextPageURL'],
	'nextPageTitle' => $uniNextPrev['nextPageTitle']
)) 

And for last page/template:

snippet('footer', array(
	'prevPageURL' => $uniNextPrev['prevPageURL'],
	'prevPageTitle' => $uniNextPrev['prevPageTitle']
)) 

Author

Russ Baldwin http://shoesforindustry.net

About

A Kirby plugin for universal next and previous links

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages