Skip to content

Commit

Permalink
Add ability to manually override templates in PageIndex
Browse files Browse the repository at this point in the history
  • Loading branch information
live627 committed Dec 24, 2024
1 parent c978ec9 commit 055054f
Showing 1 changed file with 45 additions and 5 deletions.
50 changes: 45 additions & 5 deletions Sources/PageIndex.php
Original file line number Diff line number Diff line change
Expand Up @@ -202,9 +202,19 @@ class PageIndex implements \Stringable
* "url;start=offset". Default: false.
* @param bool $show_prevnext Whether the Previous and Next links should be
* shown. Default: true.
* @param array|null $templateOverrides Array of template strings to override defaults.
* Supported keys: extra_before, previous_page, current_page, page,
* expand_pages, next_page, extra_after.
*/
public function __construct(string $base_url, int &$start, int $max_value, int $num_per_page, bool $short_format = false, bool $show_prevnext = true)
{
public function __construct(
string $base_url,
int &$start,
int $max_value,
int $num_per_page,
bool $short_format = false,
bool $show_prevnext = true,
?array $templateOverrides = null
) {
$this->base_url = $base_url;
$this->max_value = $max_value;
$this->num_per_page = $num_per_page;
Expand All @@ -225,6 +235,15 @@ public function __construct(string $base_url, int &$start, int $max_value, int $
if (!isset(Utils::$context['current_page'])) {
Utils::$context['current_page'] = $this->start / $this->num_per_page;
}

// Override templates if provided
if ($templateOverrides) {
foreach ($templateOverrides as $key => $value) {
if (property_exists($this, $key)) {
$this->{$key} = $value;
}
}
}
}

/**
Expand Down Expand Up @@ -276,11 +295,32 @@ public function __toString(): string
/**
* Static wrapper for constructor.
*
* @param string $base_url The basic URL to be used for each link.
* @param int &$start The start position, by reference. If this is not a
* multiple of the number of items per page, it is sanitized to be so and
* the value will persist upon the function's return.
* @param int $max_value The total number of items you are paginating for.
* @param int $num_per_page The number of items to be displayed on a given
* page. $start will be forced to be a multiple of this value.
* @param bool $short_format Whether to use "url.offset" instead of
* "url;start=offset". Default: false.
* @param bool $show_prevnext Whether the Previous and Next links should be
* shown. Default: true.
* @param array|null $templateOverrides Array of template strings to override defaults.
* Supported keys: extra_before, previous_page, current_page, page,
* expand_pages, next_page, extra_after.
* @return self An instance of this class.
*/
public static function load(string $base_url, int &$start, int $max_value, int $num_per_page, bool $short_format = false, bool $show_prevnext = true): self
{
return new self($base_url, $start, $max_value, $num_per_page, $short_format, $show_prevnext);
public static function load(
string $base_url,
int &$start,
int $max_value,
int $num_per_page,
bool $short_format = false,
bool $show_prevnext = true,
?array $templateOverrides = null
): self {
return new self($base_url, $start, $max_value, $num_per_page, $short_format, $show_prevnext, $templateOverrides);
}

/******************
Expand Down

0 comments on commit 055054f

Please sign in to comment.