コンソールのカスタマイズ customizing-the-consoles

CAUTION
このドキュメントでは、最新のタッチ操作対応 UI でのコンソールのカスタマイズ方法について説明します。クラシック UI には適用されません。

AEM には、オーサーインスタンスのコンソール(およびページオーサリング機能)をカスタマイズできる様々な仕組みが用意されています。

  • クライアントライブラリ
    クライアントライブラリを使用すると、デフォルトの実装を拡張して新しい機能を実現しながら、標準の関数、オブジェクト、メソッドを再利用できます。カスタマイズするときに、独自の clientlib を /apps. に作成して、カスタムコンポーネントに必要なコードを保持することなどができます。

  • オーバーレイ
    オーバーレイはノード定義にもとづいており、標準の機能(/libs)にカスタマイズした独自機能(/apps)をオーバーレイすることができます。Sling Resource Merger は継承を許可しているので、オーバーレイを作成するときに、オリジナルの 1 対 1 のコピーは必要ありません。

これらをさまざまな方法で使用して、AEM コンソールを拡張できます。一部については、以降で(大まかに)説明します。

NOTE
詳しくは、次のセクションを参照してください。
CAUTION
/libs パス内の設定は​ 一切 ​変更しないでください。
/libs コンテンツは、インスタンスを次回アップグレードするとき(場合によってはホットフィックスまたは機能パックを適用したとき)に上書きされるからです。
設定およびその他の変更に推奨される方法は次のとおりです。
  1. 必要な項目(/libs 内に存在)を、/apps の下で再作成します。

  2. /apps 内で必要な変更を加えます

例えば、/libs 構造内の以下の場所をオーバーレイできます。

  • コンソール(Granite UI ページに基づくすべてのコンソール)。次に例を示します。

    • /libs/wcm/core/content
NOTE
ヒントおよびツールについて詳しくは、ナレッジベースの記事「Troubleshooting AEM TouchUI issues」を参照してください。

コンソールのデフォルト表示のカスタマイズ customizing-the-default-view-for-a-console

コンソールのデフォルト表示(列、カード、リスト)をカスタマイズできます。

  1. 次の場所で、必要なエントリをオーバーレイすることによって、表示の順序を変更できます。

    /libs/wcm/core/content/sites/jcr:content/views

    先頭のエントリがデフォルトになります。

    使用可能なノードは、使用可能な表示オプションに関連付けられます。

    • column
    • card
    • list
  2. 例えば、リスト用のオーバーレイで、

    /apps/wcm/core/content/sites/jcr:content/views/list

    次のプロパティを定義します。

    • 名前sling:orderBefore
    • String
    • : column

ツールバーへの新規アクションの追加 add-new-action-to-the-toolbar

  1. 独自コンポーネントを作成し、カスタムアクション用のクライアントライブラリを含めることができます。例えば、次のファイルの Twitter に宣伝 ​アクションなどです。

    /apps/wcm/core/clientlibs/sites/js/twitter.js

    このアクションを独自コンソールのツールバー項目に関連付けることができます。

    /apps/<yourProject>/admin/ext/launches

    選択モードの例:

    content/jcr:content/body/content/header/items/selection/items/twitter

ツールバーアクションを特定のグループに制限 restrict-a-toolbar-action-to-a-specific-group

  1. カスタムレンダリング条件を使用すると、標準のアクションをオーバーレイし、レンダリング前に満たさなければならない具体的な条件を課すことができます。

    例えば、グループに基づいてレンダリング条件を制御するためのコンポーネントを作成します。

    /apps/myapp/components/renderconditions/group

  2. これをサイトコンソールの「サイトを作成」アクションに適用するには、

    /libs/wcm/core/content/sites

    オーバーレイを作成します。

    /apps/wcm/core/content/sites

  3. このアクションのレンダリング条件を追加します。

    jcr:content/body/content/header/items/default/items/create/items/createsite/rendercondition

    このノードのプロパティを使用して、特定のアクションを実行できる groupsadministrators など)を定義できます。

リスト表示で列のカスタマイズ customizing-columns-in-the-list-view

NOTE
この機能は、テキストフィールドの列に対して最適化されています。その他のデータタイプに対しては、/appscq/gui/components/siteadmin/admin/listview/columns/analyticscolumnrenderer をオーバーレイできます。

リストビューで列をカスタマイズするには以下の手順で行います。

  1. 使用可能な列のリストをオーバーレイします。

    • ノードの場合:

      code language-none
             /apps/wcm/core/content/common/availablecolumns
      
    • 新しい列を追加、または既存の列を削除します。

    詳しくは、オーバーレイ(および Sling Resource Merger)の使用を参照してください。

  2. 省略可能:

    • 追加データを挿入する場合は、以下を持つ PageInforProvider を記述する必要があります。
      pageInfoProviderType property.

    例として、(GitHub から)以下に添付するクラス/バンドルを参照してください。

  3. これで、リスト表示の列コンフィギュレーターで列を選択できるようになりました。

リソースのフィルタリング filtering-resources

コンソールを使用する場合、一般的なユースケースは、ユーザーがリソース(例えば、ページ、コンポーネント、アセットなど)から選択する必要がある場合です。これは、例えば、作成者が項目を選択する必要があるリストの形式をとることができます。

リストを適切なサイズに保ち、ユースケースにも関連するように、フィルターをカスタム述語の形式で実装できます。詳しくは、この記事を参照してください。

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2