ホームページ ウェブフロントエンド CSSチュートリアル Shadcn のツールチップ矢印をカスタマイズする裏技的な方法

Shadcn のツールチップ矢印をカスタマイズする裏技的な方法

Dec 31, 2024 pm 07:33 PM

導入

Shadcn は、React プロジェクトで UI コンポーネントをコピー&ペーストするための頼りになるライブラリです。よく使用されるコンポーネントの 1 つは Tooltip で、これは @radix-ui/react-tooltip の上に構築されます。

デフォルトのツールチップは次のようになります:

Hacky Way to Customize Shadcn’s Tooltip Arrows

ツールチップ矢印の追加

提供されているコンポーネントはそのまま使用しても問題なく機能しますが、ツールチップに矢印を追加するなど、さらにカスタマイズを追加したいと思うようになりました。インスピレーションを得るため、tremor.so の Tooltip コンポーネントを参考にしました。これも @radix-ui/react-tooltip に基づいています。

Hacky Way to Customize Shadcn’s Tooltip Arrows

幸いなことに、@radix-ui/react-tooltip には Arrow コンポーネントが含まれているため、矢印の追加は簡単です。これを Content コンポーネント内に含めるだけです。

import * as TooltipPrimitives from '@radix-ui/react-tooltip'

export default () => (
  <TooltipPrimitives.Provider>
    <TooltipPrimitives.Root>
      <TooltipPrimitives.Trigger />
      <TooltipPrimitives.Portal>
        <TooltipPrimitives.Content>
          <TooltipPrimitives.Arrow /> // Add the Arrow component here
        </TooltipPrimitives.Content>
      </TooltipPrimitives.Portal>
    </TooltipPrimitives.Root>
  </TooltipPrimitives.Provider>
)
ログイン後にコピー
ログイン後にコピー

しかし、矢印を含むツールチップ全体の周囲に境界線を追加したい場合はどうすればよいでしょうか?

ツールチップの境界線を追加する

これを実現するには、Arrow コンポーネントのスタイルを設定する必要があります。いくつかのアプローチを見てみましょう:

素朴なアプローチ

Tailwind クラスを使用して矢印に境界線を直接追加するのが良い出発点と思われます:

<TooltipPrimitives.Arrow
  className='border border-[var(--tooltip-border-color)] fill-[var(--tooltip-color)]'
  width={12}
  height={7}
  aria-hidden='true'
/>
ログイン後にコピー
ログイン後にコピー

しかし、このアプローチは期待どおりに機能しません。 border プロパティは、矢印の形状自体ではなく、要素の長方形の境界に適用されます。

Hacky Way to Customize Shadcn’s Tooltip Arrows

ストロークプロパティの使用

矢印は SVG 要素であるため、ストローク プロパティを使用して境界線を定義できます。

<TooltipPrimitives.Arrow
  className='border-none fill-[var(--tooltip-color)]'
  stroke='var(--tooltip-border-color)'
  stroke-width='2'
  width={12}
  height={7}
  aria-hidden='true'
/>
ログイン後にコピー

これはうまく機能しますが、矢印の上の境界線はまだ表示されています。これを修正するには、別の方法を検討してみましょう。

Hacky Way to Customize Shadcn’s Tooltip Arrows

ドロップ シャドウ オプションを調べる

もう 1 つの方法は、ドロップシャドウを使用して境界線をシミュレートすることです。

<TooltipPrimitives.Arrow
  className='-my-px border-none fill-[var(--tooltip-color)] drop-shadow-[0_1px_0_red]'
  width={12}
  height={7}
  aria-hidden='true'
/>
ログイン後にコピー

これにより、矢印と境界線を備えた視覚的にシームレスなツールチップが作成されますが、ユースケースによっては、これが常に最も正確なソリューションであるとは限りません。

Hacky Way to Customize Shadcn’s Tooltip Arrows

このソリューションは、開発時間を節約できるさまざまなカスタマイズ可能なツールチップ バリアントを提供する、Origin UI のツールチップ コンポーネントからインスピレーションを得ていることに言及する価値があります。

独自のカスタム SVG を使用するなど、さらにスタイリングしてみてはいかがでしょうか?

カスタムSVG矢印

私は Vercel の Web サイトによくアクセスしますが、そのドロップダウン ナビゲーション バー、特に 矢印 が目に留まりました。

Hacky Way to Customize Shadcn’s Tooltip Arrows

どのように設計されたのか興味があったので、開発ツールを開いて要素を調べ、SVG 矢印を見つけました。次に、それをコピーして Figma に貼り付けて、詳しく見ていきました。

Hacky Way to Customize Shadcn’s Tooltip Arrows

ツールチップの矢印としては、興味深いデザインの選択になるかもしれないと思いました。

位置決め

Hacky Way to Customize Shadcn’s Tooltip Arrows

SVG 矢印の位置は、ツールチップの配置 (、または ) によって異なります。 Content コンポーネントは、位置を動的に調整するために使用できるデータ側属性を公開します。

import * as TooltipPrimitives from '@radix-ui/react-tooltip'

export default () => (
  <TooltipPrimitives.Provider>
    <TooltipPrimitives.Root>
      <TooltipPrimitives.Trigger />
      <TooltipPrimitives.Portal>
        <TooltipPrimitives.Content>
          <TooltipPrimitives.Arrow /> // Add the Arrow component here
        </TooltipPrimitives.Content>
      </TooltipPrimitives.Portal>
    </TooltipPrimitives.Root>
  </TooltipPrimitives.Provider>
)
ログイン後にコピー
ログイン後にコピー

次に、組み込みのツールチップ Arrow コンポーネントをカスタム デザインに置き換えることができます。完璧に動作するはずですよね?

Hacky Way to Customize Shadcn’s Tooltip Arrows

そうですね、まだです。これを見てください: 矢印はトリガーの近くに配置されるのではなく、ツールチップの中央に固定されています。

Hacky Way to Customize Shadcn’s Tooltip Arrows

この望ましくない動作は、各側の静的な位置を定義しただけであるために発生します。代わりに、この問題を解決するには動的な位置を使用する必要があります。

ダイナミックポジション

組み込みの Arrow コンポーネントを再度使用してみましょう。ツールチップの位置変更をシミュレートしながら開発ツールで Arrow コンポーネントを検査すると、SVG 要素が左の CSS プロパティを持つスパンでラップされていることがわかります。

Hacky Way to Customize Shadcn’s Tooltip Arrows

この値は、ツールチップの位置に基づいて動的に変化します。この左側の CSS 値をキャプチャして、カスタム矢印コンポーネントに適用できます。

この左の値を追跡するには、MutationObserver を使用してそれを観察する必要があります。

<TooltipPrimitives.Arrow
  className='border border-[var(--tooltip-border-color)] fill-[var(--tooltip-color)]'
  width={12}
  height={7}
  aria-hidden='true'
/>
ログイン後にコピー
ログイン後にコピー

最終結果

期待どおりに動作していますか??

Hacky Way to Customize Shadcn’s Tooltip Arrows

追伸ツールチップを左側または右側に表示したい場合は、上部の位置を調整するとよいでしょう。

結論

このアプローチは機能しますが、より簡単で柔軟なツールヒントのスタイルを可能にする UI ライブラリがあると思います。ただし、これに対する回避策を見つけることができてやりがいを感じています。他のオプションを検討することに興味がある場合は、このディスカッションをチェックしてみてください。

以上がShadcn のツールチップ矢印をカスタマイズする裏技的な方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

静的フォームプロバイダーの比較 静的フォームプロバイダーの比較 Apr 16, 2025 am 11:20 AM

ここでは、「静的フォームプロバイダー」という用語を埋めてみましょう。あなたはあなたのHTMLを持ってきます

SASSをより速くするための概念の証明 SASSをより速くするための概念の証明 Apr 16, 2025 am 10:38 AM

新しいプロジェクトの開始時に、SASSコンピレーションは瞬く間に起こります。これは、特にbrowsersyncとペアになっている場合は素晴らしい気分です。

毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 Apr 17, 2025 am 10:55 AM

今週のプラットフォームニュースのラウンドアップで、Chromeは、Web開発者のロード、アクセシビリティ仕様、およびBBCの動きのための新しい属性を導入します

HTMLダイアログ要素を使用したいくつかの実践 HTMLダイアログ要素を使用したいくつかの実践 Apr 16, 2025 am 11:33 AM

これは私が初めてHTML要素を見ていることです。私はしばらくの間それを知っていましたが、まだスピンしていませんでした。かなりクールです

ペーパーフォーム ペーパーフォーム Apr 16, 2025 am 11:24 AM

購入またはビルドは、テクノロジーの古典的な議論です。自分で物を構築することは、あなたのクレジットカードの請求書にはラインアイテムがないため、安価に感じるかもしれませんが

毎週のプラットフォームニュース:テキスト間隔のブックマークレット、トップレベルの待望、新しいアンプロードインジケーター 毎週のプラットフォームニュース:テキスト間隔のブックマークレット、トップレベルの待望、新しいアンプロードインジケーター Apr 17, 2025 am 11:26 AM

今週のラウンドアップ、タイポグラフィを検査するための便利なブックマークレットである。

独自の非JavaScriptベースの分析をホストするためのオプション 独自の非JavaScriptベースの分析をホストするためのオプション Apr 15, 2025 am 11:09 AM

サイトの訪問者と使用データを追跡するのに役立つ分析プラットフォームがたくさんあります。おそらく、特にGoogleアナリティクスが広く使用されています

「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? 「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? Apr 16, 2025 pm 12:04 PM

しばらくの間、iTunesはポッドキャストの大きな犬だったので、「ポッドキャストにサブスクライブ」をリンクした場合:

See all articles