Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Release Yamada UI v2
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Hirotomo Yamada
October 17, 2025
Technology
650
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Release Yamada UI v2
Hirotomo Yamada
October 17, 2025
More Decks by Hirotomo Yamada
See All by Hirotomo Yamada
React ABC Questions
hirotomoyamada
0
990
Other Decks in Technology
See All in Technology
コミュニティの有益性 ~JAWS Days 2026 での体験を通して~ / The Benefits of a Community ~Through My Experience at JAWS Days 2026~
seike460
PRO
0
240
感情と身体を置き去りにしない、エンジニアの生きのこり方 ──いまから、ここから「自分の状態」を扱うという選択
saorimurooka
0
170
AIチャットの改善から見えた、良いAI体験とは / What Constitutes a Good AI Experience: Insights from Improving AI Chat
kubode
0
110
2026年6月23日 Syncable Tech + Start Python Club にて
hamukazu
0
140
10年間のブログ発信を振り返って見えたWebアプリケーションエンジニアとしての軌跡
stefafafan
0
170
SteampipeとExcel Power QueryでAWS構成定義書の作成を自動化する
jhashimoto
0
170
FPGAの開発コンペでZephyrを使ってみた
iotengineer22
0
170
[チョークトーク資料]AWS DevOps Agent を使いこなす / AWS Dev Ops Agent Chalk Talk AWS Summit Japan 2026
kinunori
3
720
AIネイティブな開発のサプライチェーンリスク対策 〜激動の開発現場でリスクに立ち向かう〜【ZennFes】
cscengineer
PRO
2
150
AIチャット検索改善の3週間
kworkdev
PRO
2
160
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
3k
OTel × Datadog で 「AI活用」を計測し、改善に繋げる
shihochan
2
550
Featured
See All Featured
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
600
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
320
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Marketing to machines
jonoalderson
1
5.5k
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Transcript
Yamada UI v2をリリースする
Profile Produced Contributing Hirotomo Yamada Developer of Yamada UI. Designer,
design system and UI engineer. I work for
Yamada UI v2をリリースする
リリースします
🎉
Yamada UI とは 他は、省略します。 日本発のReact UIライブラリです
新しい機能
CLI - セットアップ CLIを使用すると、プロジェクトで Yamada UIのセットアップを簡単に行うことができるようになりました。 initコマンドを実行すると、次のプロンプトが表示されます。
CLI - ダウンロード 2つの方法でコンポーネントを提供します。 1つは、CLIからコンポーネントをダウンロードする新しい方法。もう 1つは、 モジュールからコンポーネントをインポートする従来通りの方法です。 ソースコードをダウンロードすることにより、コンポーネントやフックの 初期値やロジックをカスタマイズすることがで き、ロジックなどで不具合があった場合は、直接修正する
ことができます。
CLI - ダウンロード ソースコードをダウンロードしてカスタマイズしても、 CLIのdiffやupdateを行うことで、ソースコードを簡単に更新する ことができます。もし、あなたの修正と競合しても Gitの競合の提示方法と同じ ように表示され、簡単に解決することが できます。
コンポーネント - 名前空間インポート 名前空間を使用してコンポーネントをインポートすることができるようになりました。 従来のコンポーネントを個別にインポートすることは、引き続き可能です。 但し、名前空間の兼ね合いで名前が変更されたコンポーネントがあります。 例えば、Accordionの場合は、AccordionRootに変更されています。
コンポーネント - createComponent createComponentを使用すると、バリアントなど条件付きスタイル をサポートするコンポーネントを作成することがで きます。createSlotComponentを使用すると、スロット付きコンポーネントを簡単に作成できます。 • BEMの命名規則に準拠した classNameを自動で生成する。 •
柔軟な記述方法ができる。 • 条件付きスタイルの条件は、 OR・AND・正規表現が選択でき、柔軟にマッチさせることができる。 • 条件付きスタイルで使用する propsは、スタイルを計算した後、 自動的に除外される。 • propsを多段階計算する。 • propsは、mergePropsを使用して、消失を防ぎながらマージ される。 • コンテキストを生成するので、コンテキスト内の同コンポーネントに propsを一括設定できる。
defineComponentStyleでスタイルを定義し、 createComponentから提供されるメソッドでコンポーネントを作成しま す。 コンポーネント - createComponent
BEMの命名規則に準拠した classNameを自動で生成する。 コンポーネント - createComponent
コンポーネントは柔軟な記述ができます。 コンポーネント - createComponent 条件付きスタイルのみ使用し、ロジックを持たないコンポーネントは、 HTMLの要素を指定するだけです。 従来のような関数コンポーネントも定義できます。
条件付きスタイルの条件は、 OR・AND・正規表現が選択でき、柔軟にマッチさせることができる。 コンポーネント - createComponent 配列にすることでORになります。 正規表現を使用できます。
propsを多段階計算する。 コンポーネント - createComponent 第一引数は、初期値の propsです。提供されるpropsによって上書きされるか、 マージされます。 今回のケースは、aria-labelは上書きされ、onClickの処理はマージされます。 第二引数以降は、オブジェクトまたは関数を設定されることで 多段階計算またはマージされます。
今回のケースの場合、 orientationはdata-orientationに変換され、DOMの要素にセットされません。
コンポーネント - createComponent 提供されたPropsContextを使用すると、子要素にあるコンポーネントの propsを一括で設定することができます。 上記の例では、BadgePropsContextの子要素にあるBadgeは、すべてvariantが”outline”になります。
コンポーネント - mergeProps mergePropsを使用すると、propsの消失を防ぎながらマージ を簡単に行うことができます。従来は、提供される props を配慮しながらコンポーネントを作成する必要がありました。 mergePropsを使用すると、提供される propsを配慮する ことなく、コンポーネントの作成に集中することができます。
Before After
コンポーネント - ポリモーフィズム 従来のasに加えて、asChildを追加しました。asは、コンポーネント自体の要素を変更するに対して、 asChildは、コン ポーネントの機能やスタイルを子要素に組み込む ために使用します。 as asChild
Style Props - CSSカスタムプロパティ・値関数 Style Propsで簡単にCSSカスタムプロパティを設定できるようになりました。 また、テーマのトークンを参照することができます。 Style Propsの値でCSS値関数を使用する場合に、各関数が対応するテーマの トークンを参照することができるように
なりました。
Style Props - インターポレーション Style Propsの値で簡単にCSSカスタムプロパティを参照することができるようになりました。 また、テーマのトークンを参照することができます。これは、テーマのトークンと紐づいていないプロパティに、別の テーマのトークンを設定するのに便利です。 borderなどの一括指定プロパティ で使用すると便利です。
Style Props - アットルール Style Propsにアットルールが追加されました。 コンテナクエリもサポートしています。
Style Props - アニメーション 以前のアニメーションは、 useAnimationを使用していました。これからは、 Style Propsから直接設定することができる ようになりました。 After
Before
アクセシビリティ - 国際化 アクセシビリティを向上させるため、すべてのコンポーネントで組み込まれている文字列から日付・数値のフォーマット まで、30以上の言語をサポートしました。 日本語(日本) 英語(イギリス) 英語(米国) アラビア語(アラブ首長国連邦) ブルガリア語(ブルガリア)
クロアチア語(クロアチア) チェコ語(チェコ共和国) デンマーク語(デンマーク) オランダ語(オランダ) エストニア語(エストニア) フィンランド語(フィンランド) フランス語(カナダ) フランス語(フランス) ドイツ語(ドイツ) ギリシャ語(ギリシャ) ヘブライ語(イスラエル) ハンガリー語(ハンガリー) イタリア語(イタリア) ラトビア語(ラトビア) リトアニア語(リトアニア) ノルウェー語(ノルウェー) ポーランド語(ポーランド) ポルトガル語(ブラジル) ルーマニア語(ルーマニア) ロシア語(ロシア) セルビア語(セルビア) スロバキア語(スロバキア) スロベニア語(スロベニア) スペイン語(スペイン) スウェーデン語(スウェーデン) トルコ語(トルコ) ウクライナ語(ウクライナ) 中国語(簡体字) 中国語(繁体字) 韓国語(韓国) これらの言語は、I18nProviderの言語データから簡単に更新することができ、新しい言語データを追加することも可 能です。また、バンドルサイズは言語データを削除すれば最適化できます。
ありがとうございました X @hirotomoyamada https://x.com/hirotomoyamada GitHub リポジトリ https://github.com/yamada-ui/yamada-ui ドキュメントサイト https://yamada-ui.com