buepro / typo3-auxlibs
Provides third party libraries to be used in non-composer mode. The following libraries are embedded: hashids/hashids, erusev/parsedown.
Installs: 1 297
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:typo3-cms-extension
Requires
- erusev/parsedown: ~1.7.4
- hashids/hashids: ~4.1.0
- rlanvin/php-rrule: ~2.3.0
- typo3/cms-core: ^10.4 || ^11.5.1
Requires (Dev)
- clue/phar-composer: ^1.2.0
- friendsofphp/php-cs-fixer: ^3.0.0
- friendsoftypo3/phpstan-typo3: ^0.8.1
- overtrue/phplint: ^2.3.5
- phpstan/phpstan: ^0.12.87
- phpstan/phpstan-deprecation-rules: ^0.12.6
- phpstan/phpstan-phpunit: ^0.12.19
- phpstan/phpstan-strict-rules: ^0.12.9
Replaces
- buepro/typo3-auxlibs: v1.4.0
- typo3-ter/auxlibs: v1.4.0
README
This TYPO3 extension provides 3rd party libraries to be used in non-composer mode.
Currently the following libraries are available:
Libraries
Hashids
Hashids is small PHP library to generate YouTube-like ids from numbers. Use it when you don't want to expose your database ids to the user.
Example:
$hashids = new \Hashids\Hashids; $handle = $hashids->encode(5, 5, 5);
Parsedown
Parsedown transforms text with markdown syntax to html.
Example:
$parsedown = new \Parsedown; $htmlText = $parsedown->text($markdownText);
ViewHelper
A ViewHelper is available and can be used as following:
<html xmlns:f="http://typo3.org/ns/TYPO3/CMS/Fluid/ViewHelpers" xmlns:auxlibs="http://typo3.org/ns/Buepro/Auxlibs/ViewHelpers" data-namespace-typo3-fluid="true"> <!--Inline mode--> {auxlibs:parsedown(text: textWithMarkedownSyntax)} {task.description -> auxlibs:parsedown()} <!--Tag mode--> <auxlibs:parsedown text="{task.description}" /> <auxlibs:parsedown>{task.description}</auxlibs:parsedown> </html>
The ViewHelper has the following properties:
PHP RRule
RRule is a lightweight and fast implementation of recurrence rules for PHP (RRULE from RFC 5545), to easily calculate recurring/repeating dates and events (such as in a calendar).
Example:
$rrule = new RRule('RRULE:FREQ=DAILY;UNTIL=19971224T000000Z;WKST=SU;BYDAY=MO,WE,FR;BYMONTH=1'); foreach ($rrule as $occurrence) { echo $occurrence->format('r'),"\n"; }
With RSet even more complex rules can be defined:
$rset = new RSet( "DTSTART;TZID=America/New_York:19970901T090000 RRULE:FREQ=DAILY;COUNT=3 EXRULE:FREQ=DAILY;INTERVAL=2;COUNT=1 EXDATE;TZID=America/New_York:19970903T090000 RDATE;TZID=America/New_York:19970904T090000" );
Usage
The libraries are automatically loaded in a middleware. In case a library needs to be available at an earlier stage it
might be loaded with an include statement. The include statement for the library hashids
would look as following:
use TYPO3\CMS\Core\Utility\ExtensionManagementUtility; @include 'phar://' . ExtensionManagementUtility::extPath('auxlibs') . 'Libraries/hashids-hashids.phar/vendor/autoload.php';