コンテンツにスキップ

手順

このテーマにはカスタム remark-mermaid プラグイン(plugins/remark-mermaid.mjs)が含まれており、フェンスされた ```mermaid コードブロックを <div class="mermaid-container"> ラッパーに変換します。Mermaid CDN スクリプトがページ読み込み時に SVG ダイアグラムをレンダリングします。

@\{\} ノード構文を使用して、登録済みの任意のアイコンパックからアイコンを追加します:

nodeName@{ icon: 'pack:icon-name', label: 'Display Label' }

architecture-beta ダイアグラムタイプは、アイコン装飾されたノードを持つサービスおよびグループ定義をサポートします:

service myService(pack:icon-name)[Label]
group myGroup(pack:icon-name)[Label]

以下のアイコンパックが登録されており、Mermaid ダイアグラムで使用できます。アイコンは参照時にのみ CDN から遅延ロードされます。

パック名npm パッケージ主なアイコン
hashicorp-flight@f5-sales-demo/icons-hashicorp-flightterraform-color, consul-color, vault-color, aws-color, azure-color, gcp-color, kubernetes-color, docker-color
f5-brand@f5-sales-demo/icons-f5-brandnetwork-gateway, security-firewall, security-shield-network, cloud-multi, hw-server
f5xc@f5-sales-demo/icons-f5xcweb-app-and-api-protection, bot-defense, multi-cloud-app-connect, dns-management, content-delivery-network
carbon@f5-sales-demo/icons-carboncloud-services, data-base, gateway-api, virtual-machine, load-balancer-global, firewall, dns-services, virtual-private-cloud
lucide@f5-sales-demo/icons-lucideserver, database, shield, shield-check, globe, lock, cloud, network, user
mdi@f5-sales-demo/icons-mdiserver, database, shield, cloud, lock, network, dns, vpn, router
phosphor@f5-sales-demo/icons-phosphorcloud, database, shield, globe, lock, network
tabler@f5-sales-demo/icons-tablerserver, database, shield, cloud, lock, network, route, router
azure@f5-sales-demo/icons-azurevirtual-networks, load-balancers, firewalls, virtual-network-gateways, virtual-machine, public-ip-addresses, route-tables, subnet

Mermaid ダイアグラムは、角丸と多層ボックスシャドウを持つスタイル付きコンテナでラップされます:

.mermaid-container {
border: 1px solid var(--sl-color-gray-5);
border-radius: 0.75rem;
padding: 1.5rem;
box-shadow: 0 2px 4px rgba(0,0,0,0.04), 0 8px 16px rgba(0,0,0,0.08), 0 24px 48px rgba(0,0,0,0.12);
margin-block: 1.5rem;
background: #fff;
}

Starlight のデフォルト <pre> スタイリングは mermaid ラッパーから除去され、外側のコンテナボーダーのみが表示されます:

.mermaid-container pre.mermaid {
border: none;
padding: 0;
margin: 0;
background: transparent;
}

内部の SVG はダークモード互換性のために白背景に強制されます:

.mermaid-container svg {
background: white !important;
border-radius: 0.5rem;
}
  • .mermaid-container はダークモードで白い SVG 背景を持つ
  • コンテナボーダーは --sl-color-gray-5 を使用する
  • コンテナは 0.75rem の角丸と多層ボックスシャドウを持つ
  • ダイアグラムはライトテーマおよびダークテーマの両方で読みやすい
  • Mermaid CDN スクリプトがページ読み込み時にロードされ SVG をレンダリングする