Streams Plugin

Addons

addon

The addon function returns a decorated addon instance or null if not found. The identifier argument can be a dot notation namespace or unique slug.

{{ addon('anomaly.module.users').name }}
// Users Module

{{ addon('pages').namespace('settings') }}
// anomaly.module.pages::settings

addons

The addons method returns a decorated collection of addons. An optional type argument will restrict the type of addon returned.

{{ addons() }} // All addons.

// All enabled modules.
{% for module in addons('modules').enabled() %}
    <p>{{ module.name }} is enabled.</p>
{% endfor %}

User Agent

agent_is

The agent_is function returns if the agent matches a given string.

{% if agent_is("iPhone") %}
    <p>Sweet iPhone bro.</p>
{% endif %}

agent_is_mobile

The agent_is_mobile function returns whether the user agent is a mobile browser or not.

{% if agent_is_mobile() %}
    {{ asset_style('theme::mobile.css') }}
{% endif %}

Assets

asset_add

Adds an asset to a collection. An optional array of flags is also available.

{{ asset_add("theme.js", "theme::js/vendor/*", ["min"]) }}

asset_script

The asset_script function returns the script tag to the given collection.

{{ asset_script("theme.js", ["min"]) }}

asset_scripts

The asset_scripts function returns an array of script tags for the assets within a given collection.

{% for script in asset_scripts("scripts.js", ["min"]) %}
    {{ script|raw }}
{% endfor %}

constants

The constants function returns a script tag containing a number of often required javascript constants necessary for field types and potentially other components to work correctly. Make sure you include it in your themes!

{{ constants() }}

Learn more about JS constants.

Authorization

auth_check

The auth_check function returns whether a user is logged in or not.

{% if auth_check() %}
    Hello {{ auth_user().display_name }}!
{% endif %}

auth_guest

The auth_guest function returns the opposite of auth_check.

{% if auth_guest() %}
    <a href="{{ url_route('lgoin') }}">Login</a>
{% endif %}

Theming

Breadcrumb

The breadcrumb function renders a Bootstrap breadcrumb.

{{ breadcrumb() }}

You can use this function as an array to generate your own breadcrumb:

<ol class="breadcrumb">
    {% for breadcrumb, url in breadcrumb() %}
        {% if loop.last %}
            <li class="breadcrumb-item active">{{ trans(breadcrumb) }}</li>
        {% else %}
            <li class="breadcrumb-item"><a href="{{ url }}">{{ trans(breadcrumb) }}</a></li>
        {% endif %}
    {% endfor %}
</ol>

favicons

The favicons function renders multiple favicon tags based on a single source.

You can use this function to automatically generate comprehensive and modern favicon tags:

{{ favicons('theme::img/favicon.png') }}

The above function will generate the below favicons using the streams::partials/favicons view:

<link rel="icon" type="image/png" href="{{ image(source).resize(16, 16).path }}" sizes="16x16"/>
<link rel="icon" type="image/png" href="{{ image(source).resize(32, 32).path }}" sizes="32x32"/>
<link rel="icon" type="image/png" href="{{ image(source).resize(96, 96).path }}" sizes="96x96"/>
<link rel="icon" type="image/png" href="{{ image(source).resize(128, 128).path }}" sizes="128x128"/>
<link rel="icon" type="image/png" href="{{ image(source).resize(196, 196).path }}" sizes="196x196"/>
<link rel="apple-touch-icon-precomposed" sizes="57x57" href="{{ image(source).resize(57, 57).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="60x60" href="{{ image(source).resize(60, 60).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="72x72" href="{{ image(source).resize(72, 72).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="76x76" href="{{ image(source).resize(76, 76).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="114x114" href="{{ image(source).resize(114, 114).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="120x120" href="{{ image(source).resize(120, 120).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="144x144" href="{{ image(source).resize(144, 144).path }}"/>
<link rel="apple-touch-icon-precomposed" sizes="152x152" href="{{ image(source).resize(152, 152).path }}"/>

Miscellaneous

carbon

The carbon function provides access to Carbon.

{{ carbon().today() }}
// 2016-06-24 00:00:00

{{ carbon('-1 day', config('app.timezone')) }}
// "2016-08-17 15:05:26"

{{ carbon('-1 day', config('app.timezone')).diffInHours() }}
// 24

Currency

currency_format

The currency_format function returns the number in currency format proceeded by the system configured currency symbol.

You may also specify an optional currency code to use specifically. The system configured currency will be used by default.

Lastly you can specify an array of options to change configured behavior. Available options are direction, separator, decimals, and point.

{{ currency_format(number) }}
{{ currency_format(number, currency) }}
{{ currency_format(number, currency, options) }}

// Sum up the "amount" of a collection of entries.
// Assuming "amount" is an integer field type.
{{ currency_format(payments.sum('amount.value')) }}
// $12,712.93

currency_normalize

The currency_normalize function returns the number in currency format without the system configured currency symbol.

You may also specify an optional currency code to use specifically. The system configured currency will be used by default.

Lastly you can specify an array of options to change configured behavior. Available options are direction, separator, decimals, and point.

{{ currency_normalize(number) }}
{{ currency_normalize(number, currency) }}
{{ currency_normalize(number, currency, options) }}

// Sum up the "amount" of a collection of entries.
// Assuming "amount" is an integer field type.
{{ currency_normalize(payments.sum('amount.value'), 'USD', {'separator': ''}) }}
// 12712.93

CSRF

csrf_token

The csrf_token function returns the CSRF token value.

{{ csrf_token() }}
// Uge4akcwu7HyGLEeJ3uJseqUCRxk9Yz6B7Yi0kkG

csrf_field

The csrf_field function returns the name of the CSRF field.

{{ csrf_field() }}
// <input type="hidden" name="_token" value="Uge4akcwu7HyGLEeJ3uJseqUCRxk9Yz6B7Yi0kkG">

Entries

entries

The entries function provide you with a convenient, fluent interface to fetch stream entries.

<ul>
    {% for category in entries('posts', 'categories').get() %}
    <li>
        {{ category.slug }}
    </li>
    {% endfor %}
</ul>

You can interact with entries before firing get just like you would a query builder.

{% set products = entries('store', 'products')
    .where('featured', true)
    .order_by('rating','DESC')
    .get() %}

<ul>
    {% for product in products %}
    <li>
        {{ product.name }}
    </li>
    {% endfor %}
</ul>

The entry criteria is extendable! To learn how to add your own functionality to queries refer to the criteria documetation.

query

The query function aids in fetching database records that are not streams.

{% set jobs = query()
    .from('failed_jobs')
    .orderBy('failed_at', 'DESC'
    .get() %}

You can also provide a model to use instead of specifying with from(table):

{% set users = query('App\Example\TestModel')
    .where('active', true)
    .orderBy('failed_at', 'DESC'
    .get() %}

In order to leverage model criteria you must provide a model.

Environment

env

You can access environmental variable values with the env function. This function behaves just like the Laravel helper function.

{% if env(key, default) %}
    True
{% endif %}

{% if env("APP_DEBUG") %}
    You are debugging!
{% endif %}

Footprint

request_time

The request_time function returns the elapsed time in seconds for the request. You can optionally specify the number of decimals to return. The default is 1.

{{ request_time(3) }}
// 0.551

memory_usage

The memory_usage function returns the memory used by the request. You can optionally specify the number of decimals to return. The default is 1.

{{ memory_usage(2) }}
// 6.51 m

Images

Learn more about working with images.

img

The img function returns an image instance with <img> as the default output method.

{{ image('theme::img/logo.png')|raw }}
// <img src="/app/default/assets/addons/default/mysite/example-theme/resources/images/logo.png?v=1549566000" alt="Logo">

You can fluently chain methods together to manipulate the image:

{{ image('theme::img/logo.png').resize(1000).quality(60)|raw }}
// <img src="/app/default/assets/addons/default/mysite/example-theme/resources/images/082f74498bc34c1f37fbd56818417350.png?v=1549566000" alt="Logo">

You can also specify alternate output methods:

<img src="{{ image('theme::img/logo.png').path }}">
// /app/default/assets/addons/default/anomaly/example-theme/resources/images/logo.png?v=1549566000

<img src="{{ image('theme::img/logo.png').height(95).inline|raw }}">
// <img alt="Logo" height="95" src="">

Requests

request

The request function returns the request object. For example you can get the route's id parameter like this:

{{ request().route('id') }}
// 123

request_get

The request_get function returns $_GET parameters from the request.

{{ request_get(parameter, default) }}

request_method

The request_method function returns the request's method verb.

{% if request_method() == 'GET' %}
    <p>Lemme GET that for you.</p>
{% endif %}

request_root

The request_root function returns the request root.

{{ request_root() }}
// http://domain.com/

request_path

The request_path function returns the request path.

{{ request_path() }}
// /the/uri/path

request_segment

The request_segment function returns the specified URI segment.

{{ request_segment(1) }}
// admin

request_is

The request_is function returns if the request path matches a pattern. If multiple patterns are provided then true will be returned if any match.

{{ request_is("myaccount/*", "account/*") }}
// true or false

request_ajax

The request_ajax function whether or not the request is ajax.

{{ request_ajax() }}
// true or false

Session

session_get

The session_get function returns a value from session.

{{ session_get(key) }}
{{ session_get(key, default) }}

session_pull

The session_pull function returns and removes a value from session.

{{ session_pull(key) }}
{{ session_pull(key, default) }}

session_has

The session_has function returns whether the session has a value by key or not.

{% if session_has(key) %}
    <p>Party in da house!</p>
{% endif %}

Strings

Learn more about working with strings.

str_humanize

The str_humanize function returns the humanized version of a string. The separator is - by default. This is a common way to transform slugs into human readable names.

{{ str_humanize(string, separator) }}

str_truncate

The str_truncate function returns a truncated string of a given length while preserving words. The end argument defaults to ....

{{ str_truncate(string, length, end) }}

str_is

The str_is function returns whether or not the provided string matches the pattern. You can use * in your pattern as a wildcard.

{% if str_is(pattern, string) %}
    <p>The pattern matches!</p>
{% endif %}

str_camel

The str_camel function returns the camel case version of a string.

{{ str_camel(string) }}

str_studly

The str_studly function returns the studly cased version of a string.

{{ str_studly(string) }}

str_random

The str_random function returns a random string. The length argument defaults to 16.

{{ str_random(10) }}

Localization

trans

The trans function returns the translated string from a key.

{{ trans("anomaly.module.users::addon.name") }}
// Users Module

You can optionally provide an array of data to replace in the string as well as a locale. The current locale will be used by default.

{{ trans(key, replace, locale) }}

trans_has

The trans_has function returns whether or not the given translation key exists. You may also specify an optional locale. The current locale will be used by default.

{{ trans_has(key) }}
{{ trans(key, locale) }}

URLs

Learn more about URL generation.

url

The url function returns an absolute URL to a given path. An array of extra parameters may be passed to build a query string. Lastly a secure flag (true or false) may also be used to force HTTPS in the generated URL. Your current request protocol will be used by default.

{{ url(path) }}
{{ url(path, extra) }}
{{ url(path, extra, secure) }}

url_secure

The url_secure function returns an absolute URL to a given path while forcing HTTPS. An array of extra parameters may be passed to build a query string.

{{ url_secure(path) }}
{{ url_secure(path, extra) }}

url_route

The url_route function returns the URL to a given named route. An array of extra parameters may be passed to build a query string and replace variables in the route path. Lastly a secure flag (true or false) may also be used to force HTTPS in the generated URL. Your current request protocol will be used by default.

{{ url_route(path) }}
{{ url_route(path, extra) }}
{{ url_route(path, extra, secure) }}

Views

view

The view function returns a rendered view. This method is similar to Twig's include tag.

{{ view(view) }}

You may also pass an array of data to use within the specified view.

{{ view('example.module.test::example/view', {'foo': 'Bar'}) }}

parse

The parse function parses a string as a template.

{{ parse(template) }}

You may also pass an array of data to use within the specified template.

{{ parse("This is a template {{ foo }}", {"foo": "bar"}) }}

This can be helpful if you need to render content from something like a textarea value.

{{ parse(entry.simple_content.value) }}

value

The value function value parses a string for an entry.

{{ value(parameters, entry) }}

layout

The layout method checks for and returns a theme layout or returns the default if it's not found. The default layout is theme::layouts/default by default.

{% extends layout(layout) %}
{% extends layout(layout, default) %}

Most modules specify a layout named after the addon and default normally. This way if it exists great, otherwise use the default layout which always exists.

{% extends layout('posts') %}