hashandsalt/kirby-chopper

Kirby 3 Chopper plugin for truncating text

Installs: 1 381

Dependents: 0

Suggesters: 0

Security: 0

Stars: 26

Watchers: 2

Forks: 2

Open Issues: 0

Type:kirby-plugin

3.0.0 2022-04-16 10:17 UTC

This package is auto-updated.

Last update: 2025-01-16 16:34:08 UTC


README

Kirby's built in Excerpt takes an all or nothing approach to stripping html tags, and only works on characters. This plugin creates excerpts from fields via KirbyText but keeps any HTML tags, with the ability to define the tags you wish to keep. Also works on whole words, as well as characters.

Commerical Usage

This plugin is free but if you use it in a commercial project please consider to

Installation

Manual

To use this plugin, place all the files in site/plugins/chopper/.

Composer

composer require hashandsalt/kirby-chopper

Usage

Defaults to limiting to 250 charchters, maintaining whole words, so if you just want 20 words and an ellipsis on the end:

<?= $page->yourtextfield()->chopper() ?>

To set number of charachters to trim to

<?= $page->yourtextfield()->chopper(100) ?>

To trim to 50 charachters, maintaining whole words, append an arrow on the on the end:

<?= $page->yourtextfield()->chopper(50, ['ellipsis', '→']) ?>

To change the default list of kept tags, add this line to your config.php and amend accordingly:

'hashandsalt.chopper.keep' => '<p><a><strong><em><sub><sup><blockquote><figure><img><h1><h2><h3><h4><h5><h6>',

To append every time an arrow at the end, add this line to your config.php:

'hashandsalt.chopper.ellipsis' => '→',

Options

Full list of options

'hashandsalt.chopper.ellipsis' => '…',
'hashandsalt.chopper.exact' => true,
'hashandsalt.chopper.html' => true,
'hashandsalt.chopper.trimWidth' => false,
'hashandsalt.chopper.keep' => '<p><a><strong><em><sub><sup><blockquote><figure><img><h1><h2><h3><h4><h5><h6>',

Requirements

This plugin was built using Kirby 3.6. Will not work on earlier versions. Requires PHP 7.4+

Credits

Based on text functions in CakePHP https://cakephp.org/