SCF Handlebars ヘルパー scf-handlebars-helpers

Handlebars ヘルパー(ヘルパー)は、SCF コンポーネントの操作を容易にするために Handlebars スクリプトから呼び出すメソッドです。

この実装には、クライアント側とサーバー側の定義が含まれます。 開発者がカスタムヘルパーを作成することもできます。

AEM Communitiesで提供されるカスタム SCF ヘルパーは、 クライアントライブラリ:

  • /etc/clientlibs/social/commons/scf/helpers.js

短縮 abbreviate

maxWords および maxLength プロパティに準拠した省略文字列を返すヘルパーです。

省略する文字列は、コンテキストとして提供されます。 コンテキストを指定しない場合、空の文字列が返されます。

最初に、コンテキストが maxLength にトリミングされ、次に、コンテキストが単語に切り離され、maxWords に縮小されます。

safeString が true に設定されている場合、返される文字列は SafeString です。

パラメーター parameters

  • context:文字列

    (オプション)デフォルトは空の文字列です。

  • maxLength:数値

    (オプション)デフォルトはコンテキストの長さです。

  • maxWords:数値

    (オプション)デフォルトは、トリミングされた文字列内の単語数です。

  • safeString:ブール値

    (オプション)true の場合、Handlebars.SafeString() を返します。 デフォルトは false です。

examples

{{abbreviate subject maxWords=2}}

/*
If subject =
    "AEM Communities - Site Creation Wizard"

Then abbreviate would return
    "AEM Communities".
*/
{{{abbreviate message safeString=true maxLength=30}}}

/*
If message =
    "The goal of AEM Communities is to quickly create a community engagement site."

Then abbreviate would return
    "The goal of AEM Communities is"
*/

Content-loadmore content-loadmore

div の下に 2 つのスパンを追加するヘルパーです。1 つは全文用、もう 1 つは短い文字用で、もう 1 つは 2 つのビューを切り替える機能です。

パラメーター parameters-1

  • context:文字列

    (オプション)デフォルトは空の文字列です。

  • numChars:数値

    (オプション)全文を表示しない場合に表示する文字数。 初期設定は 100 です。

  • moreText:文字列

    (オプション)表示するテキストが増えたことを示す、表示するテキストです。 デフォルトは"more"です。

  • ellipsesText:文字列

    (オプション)非表示のテキストがあることを示す、表示するテキストです。 初期設定は「。…」です。

  • safeString:ブール値

    (オプション)結果を返す前に Handlebars.SafeString() を適用するかどうかを示すブール値。 デフォルトは false です。

example

{{content-loadmore  context numChars=32  moreText="go on"  ellipsesText="..." }}

/*
If context =
    "Here is the initial less content and this is more content."

Then content-loadmore would return
    "Here is the initial less content<span class="moreelipses">...</span> <span class="scf-morecontent"><span>and this is more content.</span>  <a href="" class="scf-morelink" evt="click=toggleContent">go on</a></span>"
*/

DateUtil dateutil

書式設定された日付文字列を返すヘルパーです。

パラメーター parameters-2

  • context:数値

    (オプション)1970 年 1 月 1 日(エポック)からのミリ秒のオフセット値。 初期設定は現在の日付です。

  • 形式:文字列

    (オプション)適用する日付フォーマット。 デフォルトは"YYYY-MM-DDTHH:mm:ss.sssZ」と表示され、結果は「2015-03-18T18:17:13-07:00"

examples-1

{{dateUtil this.memberSince format="dd MMM yyyy, hh:mm"}}

// returns "18 Mar 2015, 18:17"
{{dateUtil this.birthday format="MM-DD-YYYY"}}

// returns "03-18-2015"

次と等しい equals

等価条件に応じてコンテンツを返すためのヘルパーです。

パラメーター parameters-3

  • lvalue:文字列

    比較する左側の値。

  • rvalue:文字列

    比較する右側の値。

example-1

{{#equals  value "some-value"}}
  <div>They are EQUAL!</div>
`{{else}}`
  <div>They are NOT equal!</div>
{{/equals}}

If-wcm-mode if-wcm-mode

の現在の値をテストするブロックヘルパー WCM モード を、文字列区切りのモードのリストに対して呼び出します。

パラメーター parameters-4

  • context:文字列

    (オプション)翻訳する文字列です。 デフォルトを指定しない場合は必須です。

  • mode:文字列

    (オプション) WCM モード をテストします。

example-2

{{#if-wcm-mode mode="DESIGN, EDIT"}}
 ...
{else}}
 ...
`{{/if-wcm-mode}}`

i18n i-n

このヘルパーは、Handlebars ヘルパー「i18n」を上書きします。

関連トピック JavaScript コードの文字列の国際化.

パラメーター parameters-5

  • context:文字列

    (オプション)翻訳する文字列です。 デフォルトを指定しない場合は必須です。

  • デフォルト:文字列

    (オプション)翻訳するデフォルトの文字列です。 コンテキストを指定しない場合は必須です。

  • コメント:文字列

    (オプション)翻訳のヒント

example-3

{{i18n "hello"}}
{{i18n "hello" comment="greeting" default="bonjour"}}

包含 include

コンポーネントをテンプレート内の既存のリソース以外として含めるためのヘルパーです。

このメソッドを使用すると、リソースを JCR ノードとして追加した場合よりも簡単に、プログラムによって容易にカスタマイズできます。 詳しくは、 コミュニティコンポーネントを追加または含める.

含めることができるコミュニティコンポーネントは、一部のみです。

このヘルパーは、サーバー側にのみ適用され、次のような機能を提供します。 cq:include (JSP スクリプト用)

パラメーター parameters-6

  • context:文字列またはオブジェクト。

    (相対パスを指定しない場合はオプション)

    用途 this 現在のコンテキストを渡す。

    用途 this.id 資源を得る id リクエストされた resourceType をレンダリングするために使用します。

  • resourceType:文字列

    (オプション)リソースタイプのデフォルトは、コンテキストからのリソースタイプです。

  • テンプレート:文字列

    コンポーネントスクリプトのパス。

  • パス:文字列

    (必須)リソースへのパス。 path が相対パスの場合は、コンテキストを指定する必要があります。そうでない場合は、空の文字列が返されます。

  • authoringDisabled:ブール値

    (オプション)デフォルトは false です。 内部でのみ使用します。

example-4

{{include this.id path="comments" resourceType="social/commons/components/hbs/comments"}}

次の場所に新しいコメントコンポーネントが含まれます: this.id + /comments を追加します。

IncludeClientLib includeclientlib

AEM HTML クライアントライブラリを含むヘルパーです。js、css、theme の各ライブラリを指定できます。 js や css など、異なるタイプの複数のインクルージョンの場合、このタグは Handlebars スクリプトで複数回使用する必要があります。

このヘルパーは、サーバー側にのみ適用され、次のような機能を提供します。 ui:includeClientLib (JSP スクリプト用)

パラメーター parameters-7

  • カテゴリ:文字列

    (オプション)クライアントライブラリカテゴリのコンマ区切りリストです。 指定されたカテゴリのすべての JavaScript ライブラリと CSS ライブラリを含めます。 テーマ名はリクエストから抽出されます。

  • テーマ:文字列

    (オプション)クライアントライブラリカテゴリのコンマ区切りリストです。 指定したカテゴリのすべてのテーマ関連ライブラリ(CSS と JS の両方)を含めます。 テーマ名はリクエストから抽出されます。

  • js:文字列

    (オプション)クライアントライブラリカテゴリのコンマ区切りリストです。 指定されたカテゴリのすべての JavaScript ライブラリを含めます。

  • css:文字列

    (オプション)クライアントライブラリカテゴリのコンマ区切りリストです。 指定されたカテゴリのすべての CSS ライブラリを含めます。

examples-2

// all: js + theme (theme-js + css)
{{includeClientLib categories="cq.social.hbs.comments, cq.social.hbs.voting"}}

// returns
    <link href="/etc/clientlibs/social/hbs/tally/voting.css" rel="stylesheet" type="text/css">
    <link href="/etc/clientlibs/social/hbs/socialgraph.css" rel="stylesheet" type="text/css">
    <link href="/etc/clientlibs/social/hbs/comments.css" rel="stylesheet" type="text/css">
    <script src="/etc/clientlibs/social/hbs/tally/voting.js" type="text/javascript"></script>
    <script src="/etc/clientlibs/social/hbs/socialgraph.js" type="text/javascript"></script>
    <script src="/etc/clientlibs/social/hbs/comments.js" type="text/javascript"></script>

// only js libs
{{includeClientLib js="cq.social.hbs.comments, cq.social.hbs.voting"}}

// returns
    <script src="/etc/clientlibs/social/hbs/tally/voting.js" type="text/javascript"></script>
    <script src="/etc/clientlibs/social/hbs/socialgraph.js" type="text/javascript"></script>
    <script src="/etc/clientlibs/social/hbs/comments.js" type="text/javascript"></script>

// theme only (theme-js + css)
{{includeClientLib theme="cq.social.hbs.comments, cq.social.hbs.voting"}}

// returns
    <link href="/etc/clientlibs/social/hbs/tally/voting.css" rel="stylesheet" type="text/css">
    <link href="/etc/clientlibs/social/hbs/comments.css" rel="stylesheet" type="text/css">
    <script src="/etc/clientlibs/social/hbs/tally/voting.js" type="text/javascript"></script>
    <script src="/etc/clientlibs/social/hbs/comments.js" type="text/javascript"></script>

// css only
{{includeClientLib css="cq.social.hbs.comments, cq.social.hbs.voting"}}

// returns
    <link href="/etc/clientlibs/social/hbs/tally/voting.css" rel="stylesheet" type="text/css">
    <link href="/etc/clientlibs/social/hbs/socialgraph.css" rel="stylesheet" type="text/css">
    <link href="/etc/clientlibs/social/hbs/comments.css" rel="stylesheet" type="text/css">

Pretty-time pretty-time

カットオフポイントに経過した時間を表示するヘルパーです。その後、通常の日付形式が表示されます。

次に例を示します。

  • 12 時間前
  • 7 日前

パラメーター parameters-8

  • context:数値

    「今」と比較する過去の時間。 時間は、1970 年 1 月 1 日(エポック)からのミリ秒の値オフセットで表されます。

  • daysCutofof:数値

    実際の日付に切り替えるまでの日数。 初期設定は 60 です。

example-5

{{pretty-time this.published daysCutoff=7}}

/*
Depending on how long in the past, may return

  "3 minutes ago"

  "3 hours ago"

  "3 days ago"
*/

Xss-html xss-html

XSS に対する保護に役立つ、HTML要素コンテンツのソース文字列をエンコードするヘルパーです。

注意:このヘルパーはバリデーターではなく、属性値の書き込みには使用されません。

パラメーター parameters-9

  • context:オブジェクト

    エンコードするHTML。

example-6

<p>{{xss-html forum-ugc}}</p>

Xss-htmlAttr xss-htmlattr

XSS に対する保護に役立つ、HTML属性値に書き込むためのソース文字列をエンコードするヘルパーです。

注意:このヘルパーはバリデーターではなく、アクションにつながる属性(href、src、イベントハンドラー)を記述する際に使用することはできません。

パラメーター parameters-10

  • context:オブジェクト

    エンコードするHTML。

example-7

<div id={{xss-htmlAttr id}} />

Xss-jsString xss-jsstring

XSS に対する保護に役立つ、JavaScript の文字列コンテンツに書き込むためのソース文字列をエンコードするヘルパーです。

注意:このヘルパーは、バリデーターではなく、任意の JavaScript に書き込むために使用することはできません。

パラメーター parameters-11

  • context:オブジェクト

    エンコードするHTML。

example-8

var input = {{xss-jsString topic-title}}

Xss-validHref xss-validhref

XSS に対する保護に役立つ、HTMLhref または srce 属性値として書き込むための URL の不要部分を削除するヘルパーです。

注意:このヘルパーは、空の文字列を返す場合があります。

パラメーター parameters-12

  • context:オブジェクト

    不要部分を削除する URL。

example-9

<a href="{{xss-validHref url}}">my link</a>

Handlebars.js の基本概要 handlebars-js-basic-overview

  • Handlebars ヘルパー呼び出しは、単純な識別子 ( 名前 (ヘルパーの)の後に、0 個以上のスペースで区切られたパラメーターが続きます。

  • パラメーターには、単純な文字列、数値、ブール値、JSON オブジェクトを指定でき、最後のパラメーターとしてキーと値のペア(ハッシュ引数)のオプションのシーケンスを指定できます。

  • ハッシュ引数のキーは、単純な識別子である必要があります。

  • ハッシュ引数の値は、単純な識別子、パス、または文字列の Handlebars 式です。

  • 現在のコンテキスト thisは、常に Handlebars ヘルパーで使用できます。

  • コンテキストは、文字列、数値、ブール値、JSON データオブジェクトのいずれかです。

  • 現在のコンテキスト内にネストされたオブジェクトを、次のようなコンテキストとして渡すことができます。 this.url または this.id (単純なヘルパーとブロックヘルパーの次の例を参照)。

  • ブロックヘルパーは、テンプレート内の任意の場所から呼び出すことができる関数です。 毎回、異なるコンテキストで、0 回以上テンプレートのブロックを呼び出すことができます。 次の間のコンテキストを含みます。 {{#*name*}} および {{/*name*}}.

  • Handlebars は、「options」という名前のヘルパーに対して最終的なパラメータを提供します。 特別なオブジェクト「options」が次を含みます

    • オプションのプライベートデータ (options.data)
    • 呼び出しからのオプションのキーと値のプロパティ (options.hash)
    • 自身を呼び出す機能 (options.fn())
    • 逆関数を呼び出す機能 (options.inverse())
  • ヘルパーから返されるHTMLー文字列のコンテンツは、SafeString にすることをお勧めします。

Handlebars.js ドキュメントの単純なヘルパーの例を次に示します。 an-example-of-a-simple-helper-from-handlebars-js-documentation

Handlebars.registerHelper('link_to', function(title, options) {
    return new Handlebars.SafeString('<a href="/posts' + this.url + '">' + title + "!</a>");
});

var context = {posts: [
    {url: "/hello-world",
      body: "Hello World!"}
  ] };

// when link_to is called, posts is the current context
var source = '<ul>`{{#posts}}`<li>{{{link_to "Post"}}}</li>`{{/posts}}`</ul>'

var template = Handlebars.compile(source);

template(context);

レンダリング:

<ul>
<li><a href="/posts/hello-world">投稿!</a></li>
</ul>

Handlebars.js ドキュメントのブロックヘルパーの例を次に示します。 an-example-of-a-block-helper-from-handlebars-js-documentation

Handlebars.registerHelper('link', function(options) {
    return new Handlebars.SafeString('<a href="/people/' + this.id + '">' + options.fn(this) + '</a>');
});

var data = { "people": [
  { "name": "Alan", "id": 1 },
  { "name": "Yehuda", "id": 2 }
]};

// when link is called, people is the current context
var source = "<ul>`{{#people}}`<li>`{{#link}}``{{name}}``{{/link}}`</li>`{{/people}}`</ul>";

var template = Handlebars.compile(source);

template(data);

レンダリング:
<ul>
<li><a href="/people/1">Alan</a></li>
<li><a href="/people/2">イェフダ</a></li>
</ul>

カスタム SCF ヘルパー custom-scf-helpers

カスタムヘルパーは、特にデータを渡す際に、サーバー側とクライアント側に実装する必要があります。 SCF の場合、ページが要求されたときにサーバーが特定のコンポーネントのHTMLを生成するので、ほとんどのテンプレートはサーバー側でコンパイルおよびレンダリングされます。

サーバー側カスタムヘルパー server-side-custom-helpers

サーバー側でカスタム SCF ヘルパーを実装して登録するには、Java™インターフェイスを実装するだけです TemplateHelper、作成する OSGi サービス OSGi バンドルの一部としてインストールします。

次に例を示します。

FooTextHelper.java footexthelper-java

/** Custom Handlebars Helper */

package com.my.helpers;

import java.io.IOException;

import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Service;

import com.adobe.cq.social.handlebars.api.TemplateHelper;
import com.github.jknack.handlebars.Options;

@Service
@Component
public class FooTextHelper implements TemplateHelper<String>{

    @Override
    public CharSequence apply(String context, Options options) throws IOException {
        return "foo-" + context;
    }

    @Override
    public String getHelperName() {
        return "foo-text";
    }

    @Override
    public Class<String> getContextType() {
        return String.class;
    }
}
NOTE
サーバー側用に作成されたヘルパーも、クライアント側用に作成する必要があります。
コンポーネントは、ログインしたユーザーのクライアント側で再レンダリングされ、クライアント側ヘルパーが見つからない場合は、コンポーネントが消えます。

クライアント側カスタムヘルパー client-side-custom-helpers

クライアント側ヘルパーは、呼び出しによって登録される Handlebars スクリプトです Handlebars.registerHelper().
次に例を示します。

custom-helpers.js custom-helpers-js

function(Handlebars, SCF, $CQ) {

    Handlebars.registerHelper('foo-text', function(context, options) {
        if (!context) {
            return "";
        }
        return "foo-" + context;
    });

})(Handlebars, SCF, $CQ);

カスタムのクライアント側ヘルパーは、カスタムのクライアントライブラリに追加する必要があります。
clientlib は以下を実行する必要があります。

  • 依存関係を含める cq.social.scf.
  • Handlebars が読み込まれた後に読み込みます。
  • Be 含む.

注意: SCF ヘルパーは、 /etc/clientlibs/social/commons/scf/helpers.js.

recommendation-more-help
81e2cd9d-0789-409d-b87c-2a8ce4f28791