Skip to content

Latest commit

 

History

History
225 lines (138 loc) · 6.97 KB

standard_library.md

File metadata and controls

225 lines (138 loc) · 6.97 KB

up, next

The Standard Library

GRMustache default configuration contains a library of predefined keys available for your templates:

HTML.escape

As a filter, HTML.escape returns its argument, HTML-escaped. Since Mustache generally provides HTML-escaping, this filter will generally be used in conjunction with other escaping filters. For example:

<script type="text/javascript">
  $("element").html("{{{ javascript.escape(HTML.escape(content))) }}}")
</script>

As a rendering object, HTML.escape escapes all inner variable tags in a section:

{{# HTML.escape }}
  {{ firstName }}
  {{ lastName }}
{{/ HTML.escape }}

Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:

{{# HTML.escape }}
  {{# items }}
    {{ name }}
  {{/}}
{{/ HTML.escape }}

See also javascript.escape, URL.escape

capitalized

This filter returns its argument, capitalized: the first character from each word is changed to its corresponding uppercase value, and all remaining characters set to their corresponding lowercase values.

{{ capitalized(firstName) }} {{ capitalized(lastName) }}

See also lowercase, uppercase.

isBlank

This filter is true if and only if its argument is "blank", that is to say nil, null, empty (empty string or empty enumerable), or a string only made of white spaces.

{{# isBlank(name) }}
  Blank name
{{^}}
  {{name}}
{{/}}

See also isEmpty.

isEmpty

This filter is true if and only if its argument is "empty", that is to say nil, null, or empty (empty string or empty enumerable).

{{# isEmpty(name) }}
  No name
{{^}}
  {{name}}
{{/}}

See also isBlank.

javascript.escape

As a filter, javascript.escape outputs a Javascript and JSON-savvy string:

<script type="text/javascript">
  var name = "{{ javascript.escape(name) }}";
</script>

As a rendering object, javascript.escape escapes all inner variable tags in a section:

<script type="text/javascript">
  {{# javascript.escape }}
    var firstName = "{{ firstName }}";
    var lastName = "{{ lastName }}";
  {{/ javascript.escape }}
</script>

Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:

<script type="text/javascript">
  {{# javascript.escape }}
    var firstName = {{# firstName }}"{{ firstName }}"{{^}}null{{/}};
    var lastName = {{# lastName }}"{{ lastName }}"{{^}}null{{/}};
  {{/ javascript.escape }}
</script>

See also HTML.escape, URL.escape

localize

Localizing a value

As a filter, localize outputs a string looked in the Localizable.string table of the main bundle:

{{ localize(greeting) }}

This would render Bonjour, given Hello as a greeting, and a French localization for Hello.

Localizing template content

As a rendering object, localize outputs the localization of a full section:

{{# localize }}Hello{{/ localize }}

This would render Bonjour, given a French localization for Hello in the Localizable.string table of the main bundle.

Warning: HTML-escaping is done as usual: you localize template snippets that are HTML chunks. There is no escaping.

Localizing template content with embedded variables

When looking for the localized string, GRMustache replaces all variable tags with "%@":

{{# localize }}Hello {{name}}{{/ localize }}

This would render Bonjour Arthur, given a French localization for Hello %@ in the Localizable.string table of the main bundle. [NSString stringWithFormat:] is used for the final interpolation.

Warning 1: HTML-escaping is done as usual: you localize template snippets that are HTML chunks. There is no escaping, but for {{name}}.

Warning 2: because of the invocation of stringWithFormat:, make sure your localized strings escape their percents. {{# localize }}%:{{name}}{{/ localize }} will render fine as long as you provide a localization for %%:%@.

Localizing template content with embedded variables and conditions

You can embed conditional sections inside:

{{# localize }}Hello {{#name}}{{name}}{{^}}you{{/}}{{/ localize }}

Depending on the name, this would render Bonjour Arthur or Bonjour toi, given French localizations for both Hello %@ and Hello you.

GRMustacheLocalizer

The localize helper is based on the GRMustacheLocalizer class. You can create your own, and localize from a specific localization table from a specific bundle:

// Will localize from the given string file from the given bundle:
GRMustacheLocalizer *localizer = [[GRMustacheLocalizer alloc] initWithBundle:... tableName:...];

id data = @{
    // With the `localize` key, this localizer overrides the default one:
    @"localize": localizer,
    ...
};

NSString *rendering = [GRMustacheTemplate renderObject:data from...];

lowercase

This filter returns a lowercased representation of its argument.

{{ lowercase(name) }}

See also capitalized, uppercase.

uppercase

This filter returns a uppercased representation of its argument.

{{ uppercase(name) }}

See also lowercase, uppercase.

URL.escape

As a filter, URL.escape returns its argument, percent-escaped.

<a href="http://google.com?q={{ URL.escape(query) }}">

As a rendering object, URL.escape escapes all inner variable tags in a section:

{{# URL.escape }}
  <a href="http://google.com?q={{ query }}&hl={{ language }}">
{{/ URL.escape }}

Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:

{{# URL.escape }}
  <a href="http://google.com?q={{ query }}{{#language}}&hl={{ language }}{{/language}}">
{{/ URL.escape }}

See also HTML.escape, javascript.escape

Get inspired

All items of the standard library are built using public APIs: check the code for inspiration:

up, next