シャドウ設定
settings.shadow
プロパティには、設定できる2つの設定があります:
defaultPresets
: デフォルトの WordPress シャドウプリセットを有効または無効にするためのブール値。デフォルトはtrue
です。presets
: テーマやユーザーで使用するためのカスタムシャドウを登録するためのオブジェクトの配列です。
ここでは、theme.json
におけるデフォルトのシャドウプロパティを見てみましょう:
{
"version": 2,
"settings": {
"shadow": {
"defaultPresets": true,
"presets": [
{
"name": "Natural",
"slug": "natural",
"shadow": "6px 6px 9px rgba(0, 0, 0, 0.2)"
},
{
"name": "Deep",
"slug": "deep",
"shadow": "12px 12px 50px rgba(0, 0, 0, 0.4)"
},
{
"name": "Sharp",
"slug": "sharp",
"shadow": "6px 6px 0px rgba(0, 0, 0, 0.2)"
},
{
"name": "Outlined",
"slug": "outlined",
"shadow": "6px 6px 0px -3px rgba(255, 255, 255, 1), 6px 6px rgba(0, 0, 0, 1)"
},
{
"name": "Crisp",
"slug": "crisp",
"shadow": "6px 6px 0px rgba(0, 0, 0, 1)"
}
]
}
}
}
ご覧のように、WordPress は、ブロックスタイルで直接使用できるいくつかのデフォルトプリセットを登録しており、ユーザーはインターフェースから選択できます:
- ナチュラル
- ディープ
- シャープ
- アウトライン
- クリスプ
すべてのプリセットと同様に、WordPress は登録された各シャドウのために CSS カスタムプロパティを生成します。シャドウプリセットは --wp--preset--shadow--{$slug}
と名付けられています。
デフォルトのシャドウプリセットのために生成された CSS の例は次のとおりです:
body {
--wp--preset--shadow--natural: 6px 6px 9px rgba(0, 0, 0, 0.2);
--wp--preset--shadow--deep: 12px 12px 50px rgba(0, 0, 0, 0.4);
--wp--preset--shadow--sharp: 6px 6px 0px rgba(0, 0, 0, 0.2);
--wp--preset--shadow--outlined: 6px 6px 0px -3px rgba(255, 255, 255, 1), 6px 6px rgba(0, 0, 0, 1);
--wp--preset--shadow--crisp: 6px 6px 0px rgba(0, 0, 0, 1);
}
コア WordPress シャドウの無効化
コアで利用可能なデフォルトのシャドウは、すべてのテーマのデザインに合わない場合があります。通常、白または非常に薄い灰色の背景を持つテーマでのみうまく機能します。テーマが異なる色を使用している場合、ほぼ常にこれらを削除したいと思うでしょう。
しかし、デフォルトを無効にする他の理由があるかもしれません。たとえば、ユーザーをテーマのために特にデザインしたシャドウのみに制限したい場合や、単にそのデザインが気に入らない場合です。
理由が何であれ、settings.shadow.defaultPresets
を false
に設定することで削除できます:
{
"version": 2,
"settings": {
"shadow": {
"defaultPresets": false
}
}
}
カスタムシャドウプリセットの追加
WordPress では、任意の数のカスタムシャドウを登録できます。settings.shadow.presets
プロパティを介して追加でき、これはシャドウオブジェクトを格納するための配列です。この配列内の各オブジェクトは、3つの値を含む必要があります:
name
: 翻訳可能なシャドウの人間が読みやすい名前またはラベル。slug
: シャドウの機械が読み取れるスラッグで、関連する CSS カスタムプロパティを構築するために使用されます。shadow
:box-shadow
CSS プロパティの有効な CSS 値です。
自分自身のシャドウをいくつか登録してみてください。この theme.json
コードを使用して開始できます。これはいくつかのシャドウの例を含んでいます:
{
"$schema": "https://schemas.wp.org/trunk/theme.json",
"version": 2,
"settings": {
"shadow": {
"presets": [
{
"name": "Small",
"slug": "sm",
"shadow": "0 1px 2px 0 rgb(0 0 0 / 0.05)"
},
{
"name": "Medium",
"slug": "md",
"shadow": "0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1)"
},
{
"name": "Large",
"slug": "lg",
"shadow": "0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)"
},
{
"name": "XL",
"slug": "xl",
"shadow": "0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)"
},
{
"name": "2XL",
"slug": "2-xl",
"shadow": "0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1)"
},
{
"name": "Inner",
"slug": "inner",
"shadow": "inset 0 2px 4px 0 rgb(0 0 0 / 0.05)"
}
]
}
}
}
現在、これはユーザーインターフェースのコアボタンブロックのためのシャドウオプションのみを表示しています。このコントロールは、WordPress 管理の 外観 > エディター > スタイル > スタイルブック を介してアクセスできます。そこから、ボタン ブロックを選択し、効果 タブにある シャドウ オプションを見つけます。次のように表示されます:
サードパーティのブロックもシャドウプリセットを利用し、投稿、テンプレート、またはサイトエディターのインターフェースに表示することが可能です。
他のプリセットと同様に、theme.json
スタイル でカスタムシャドウ(またはコア WordPress シャドウ)を使用することもできます。
この機能についての詳細は、WordPress 開発者ブログの テーマのための box-shadow 機能の使用 をお読みください。