cpsit / cps-utility
Collection of utilities to use in TYPO3 Extensions.
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 12
Forks: 0
Open Issues: 0
Type:typo3-cms-extension
Requires
- typo3/cms-core: ^11.5 || ^12.4
Requires (Dev)
- roave/security-advisories: dev-master
README
Collection of utilities to use in TYPO3 Extensions.
Utilities
Page Utility
expandPagesWithSubPages
Retrieves subpages of given page(s) recursively until depth ist reached.
Usage: $pageUtility->expandPagesWithSubPages([...], 0)
resolveStoragePages
Resolve a list of given page(s) recursively until depth ist reached.
Usage: $pageUtility->resolveStoragePages([...], 0)
TypoScript Utility
Useful function to parse TypoScript configuration array.
Data Processors
Transform variables stored in flex form into an array.
Usage:
10 = Cpsit\CpsUtility\DataProcessor\FlexFormDataProcessor
10 {
field = pi_flexform
as = flexFormData
valuePath = data|sDEF
valuePathDelimiter = |
}
View helpers
Explode view helper
Explode view helper Split a string by a string.
Wrapper for PHPs :php:explode
function.
See https://www.php.net/manual/en/function.explode.php
Usage:
<f:iterator.explode glue="," limit="10" as="varName">text,text,text</f:iterator.explode>
Inline notation: {text_to_split -> f:iterator.explode()}
without as
parameter returns an array.
Title Tag ViewHelper
ViewHelper to render the page title tag Example: Basic Example
<cps:titleTag>{item.title}</fr:titleTag>
Meta Tag ViewHelper
ViewHelper to render meta tags
Example: Basic Example: News title as og:title meta tag
<cps:metaTag property="og:title" content="{newsItem.title}" />
Example: Force the attribute "name"
<cps:metaTag name="keywords" content="{newsItem.keywords}" />`
Header Data ViewHelper
ViewHelper to render data in section of website
Example: Basic example
<lib:headerData>
<link rel="alternate"
type="application/rss+xml"
title="RSS 2.0"
href="{f:uri.page(additionalParams: '{type:1600292946}')}" />
</lib:headerData>
Output
<link rel="alternate"
type="application/rss+xml"
title="RSS 2.0"
href="uri to this page and type 9818" />
TCA
Input tags element.
Custom form element to display comma-separated values as tags. Based on [bootstrap-tagsinput] (https://github.com/bootstrap-tagsinput/bootstrap-tagsinput) package
Usage in TCA:
'field' => [
'config' => [
'type' => 'input',
'renderType' => 'inputTags',
'max' => 255,
'eval' => 'trim'
]
],
Traits
Trait to add cache tags to pages
Trait to add cache tags to pages in FE context
Usage:
- Add trait to your class
use Cpsit\CpsUtility\Traits\FeCacheTagsTrait;
. - Call method
$this->addCacheTags(['tag1','tag2')
were needed.