コンソールのカスタマイズ customizing-the-consoles
AEM には、オーサーインスタンスのコンソール(およびページオーサリング機能)をカスタマイズできる様々な仕組みが用意されています。
-
クライアントライブラリ
クライアントライブラリを使用すると、デフォルトの実装を拡張して新しい機能を実現しながら、標準の関数、オブジェクト、メソッドを再利用できます。カスタマイズするときに、独自の clientlib を/apps.
に作成して、カスタムコンポーネントに必要なコードを保持することなどができます。 -
オーバーレイ
オーバーレイはノード定義にもとづいており、標準の機能(/libs
)にカスタマイズした独自機能(/apps
)をオーバーレイすることができます。Sling Resource Merger は継承を許可しているので、オーバーレイを作成するときに、オリジナルの 1 対 1 のコピーは必要ありません。
これらをさまざまな方法で使用して、AEM コンソールを拡張できます。一部については、以降で(大まかに)説明します。
/libs
パス内の設定は 一切 変更しないでください。/libs
コンテンツは、インスタンスを次回アップグレードするとき(場合によってはホットフィックスまたは機能パックを適用したとき)に上書きされるからです。-
必要な項目(
/libs
内に存在)を、/apps
の下で再作成します。 -
/apps
内で必要な変更を加えます
例えば、/libs
構造内の以下の場所をオーバーレイできます。
-
コンソール(Granite UI ページに基づくすべてのコンソール)。次に例を示します。
/libs/wcm/core/content
コンソールのデフォルト表示のカスタマイズ customizing-the-default-view-for-a-console
コンソールのデフォルト表示(列、カード、リスト)をカスタマイズできます。
-
次の場所で、必要なエントリをオーバーレイすることによって、表示の順序を変更できます。
/libs/wcm/core/content/sites/jcr:content/views
先頭のエントリがデフォルトになります。
使用可能なノードは、使用可能な表示オプションに関連付けられます。
column
card
list
-
例えば、リスト用のオーバーレイで、
/apps/wcm/core/content/sites/jcr:content/views/list
次のプロパティを定義します。
- 名前:
sling:orderBefore
- 型:
String
- 値:
column
- 名前:
ツールバーへの新規アクションの追加 add-new-action-to-the-toolbar
-
独自コンポーネントを作成し、カスタムアクション用のクライアントライブラリを含めることができます。例えば、次のファイルの 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
-
カスタムレンダリング条件を使用すると、標準のアクションをオーバーレイし、レンダリング前に満たさなければならない具体的な条件を課すことができます。
例えば、グループに基づいてレンダリング条件を制御するためのコンポーネントを作成します。
/apps/myapp/components/renderconditions/group
-
これをサイトコンソールの「サイトを作成」アクションに適用するには、
/libs/wcm/core/content/sites
オーバーレイを作成します。
/apps/wcm/core/content/sites
-
このアクションのレンダリング条件を追加します。
jcr:content/body/content/header/items/default/items/create/items/createsite/rendercondition
このノードのプロパティを使用して、特定のアクションを実行できる
groups
(administrators
など)を定義できます。
リスト表示で列のカスタマイズ customizing-columns-in-the-list-view
/apps
の cq/gui/components/siteadmin/admin/listview/columns/analyticscolumnrenderer
をオーバーレイできます。リストビューで列をカスタマイズするには以下の手順で行います。
-
使用可能な列のリストをオーバーレイします。
-
ノードの場合:
code language-none /apps/wcm/core/content/common/availablecolumns
-
新しい列を追加、または既存の列を削除します。
詳しくは、オーバーレイ(および Sling Resource Merger)の使用を参照してください。
-
-
省略可能:
- 追加データを挿入する場合は、以下を持つ PageInforProvider を記述する必要があります。
pageInfoProviderType
property.
例として、(GitHub から)以下に添付するクラス/バンドルを参照してください。
- 追加データを挿入する場合は、以下を持つ PageInforProvider を記述する必要があります。
-
これで、リスト表示の列コンフィギュレーターで列を選択できるようになりました。
リソースのフィルタリング filtering-resources
コンソールを使用する場合、一般的なユースケースは、ユーザーがリソース(例えば、ページ、コンポーネント、アセットなど)から選択する必要がある場合です。これは、例えば、作成者が項目を選択する必要があるリストの形式をとることができます。
リストを適切なサイズに保ち、ユースケースにも関連するように、フィルターをカスタム述語の形式で実装できます。詳しくは、この記事を参照してください。