Temalandırma
Temalandırma
Temaları kullanma ve özelleştirme
RainbowKit UI'ı markanızla uyumlu hale getirebilirsiniz. Önceden tanımlanmış birkaç vurgu rengi ve kenar yarıçapı yapılandırmasından seçim yapabilirsiniz.
3 yerleşik tema işlevi vardır:
lightTheme (varsayılan)
darkTheme
midnightTheme
Bir tema işlevi bir tema nesnesi döndürür. Nesneyi RainbowKitProvider'ın theme prop'una geçirebilirsiniz.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
export const App = ( ) => (
< RainbowKitProvider theme = { darkTheme ( ) } { ... etc} >
{ }
</ RainbowKitProvider >
) ;
İsterseniz, accentColor, accentColorForeground, borderRadius, fontStack ve overlayBlur ayarlarını özelleştirebilirsiniz.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
export const App = ( ) => (
< RainbowKitProvider
theme = { darkTheme ( {
accentColor : '#7b3fe4' ,
accentColorForeground : 'white' ,
borderRadius : 'small' ,
fontStack : 'system' ,
overlayBlur : 'small' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
Yerleşik tema işlevleri ayrıca bir seçenekler nesnesi kabul eder ve birkaç farklı görsel stil seçmenize olanak tanır.
Prop Type Default accentColorInformation string "#0E76FD"accentColorForegroundInformation string "white"borderRadiusInformation enum Information largefontStackInformation enum Information roundedoverlayBlurInformation enum Information none
Örneğin, koyu temayı mor vurgu rengi ve orta kenar yarıçapı ölçeği ile özelleştirmek için:
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
accentColor: '#7b3fe4' ,
accentColorForeground: 'white' ,
borderRadius: 'medium' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Her tema aynı zamanda birkaç vurgu rengi ön ayarı (mavi, yeşil, turuncu, pembe, mor, kırmızı) sağlar ve bu ayarları seçenekler nesnesine yayabilirsiniz. Örneğin, pembe vurgu rengi ön ayarını kullanmak için:
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
... darkTheme. accentColors . pink ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
İşte theme prop'unu kullanabileceğiniz birkaç farklı yol.
darkTheme temasını kullanın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
export const App = ( ) => (
< RainbowKitProvider theme = { darkTheme ( ) } { ... etc} >
{ }
</ RainbowKitProvider >
) ;
midnightTheme temasını kullanın.
import {
RainbowKitProvider ,
midnightTheme,
} from '@rainbow-me/rainbowkit' ;
export const App = ( ) => (
< RainbowKitProvider theme = { midnightTheme ( ) } { ... etc} >
{ }
</ RainbowKitProvider >
) ;
İşte accentColor ayarını kullanabileceğiniz birkaç farklı yol.
Vurgu rengini özel bir mor değere ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
accentColor: '#7b3fe4' ,
accentColorForeground: 'white' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Vurgu rengini yerleşik yeşil ön ayarına ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
... darkTheme. accentColors . green ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
borderRadius ayarını kullanabileceğiniz birkaç farklı yol burada.
Kenar yarıçapını orta olarak ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
borderRadius: 'medium' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Kenar yarıçapını yok olarak ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
borderRadius: 'none' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Hatırlatma: Mevcut kenar yarıçapı değerleri: büyük (varsayılan), orta, küçük ve yok.
Varsayılan olarak, fontStack yuvarlak olarak ayarlanmış durumda. Ancak fontStack ayarını nasıl kullanabileceğiniz burada.
Font kümesini sistem olarak ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
fontStack: 'system' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Varsayılan olarak, overlayBlur yok olarak ayarlanmış durumda. Ancak overlayBlur ayarını nasıl kullanabileceğiniz burada.
Arka plan bulanıklığını küçük olarak ayarlayın.
import { RainbowKitProvider , darkTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { darkTheme ( {
overlayBlur: 'small' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Farklı temaları accentColor, borderRadius ve fontStack özellikleriyle birlikte nasıl kullanabileceğiniz bazı yollar burada.
lightTheme temasını kullanın
Vurgu rengini özel bir mor değere ayarlayın
Kenar yarıçapını orta olarak ayarlayın
Font kümesini sistem olarak ayarlayın
import { RainbowKitProvider , lightTheme } from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { lightTheme ( {
accentColor: '#7b3fe4' ,
accentColorForeground: 'white' ,
borderRadius: 'medium' ,
fontStack: 'system' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
midnightTheme temasını kullanın
Vurgu rengini yerleşik pembe ön ayarına ayarlayın.
Kenar yarıçapını küçük olarak ayarlayın
Font kümesini sistem olarak ayarlayın
import {
RainbowKitProvider ,
midnightTheme,
} from '@rainbow-me/rainbowkit' ;
const App = ( ) => {
return (
< RainbowKitProvider
theme = { midnightTheme ( {
... midnightTheme. accentColors . pink ,
borderRadius: 'small' ,
fontStack: 'system' ,
} ) }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;
} ;
Uygulamanız, açık ve koyu modlar arasında geçiş yapmak için standart prefers-color-scheme: dark medya sorgusunu kullanıyorsa, lightMode ve darkMode değerlerini içeren dinamik bir tema nesnesi sağlamayı tercih edebilirsiniz.
import {
RainbowKitProvider ,
lightTheme,
darkTheme,
} from '@rainbow-me/rainbowkit' ;
const App = ( ) => (
< RainbowKitProvider
theme = { {
lightMode: lightTheme ( ) ,
darkMode: darkTheme ( ) ,
} }
{ ... etc}
>
{ }
</ RainbowKitProvider >
) ;