ステートの切り替えができる、ボタンUIコンポーネントの作り方
こんにちは、UIデザイナーの水澤です。
弊社では職能横断チームとして、職種の垣根を超えた情報共有が増えてきています。
今回の記事も、Figma を使ってどのようにステートの切り替えができるコンポーネントを作っているのか、デザイナー以外の方にも理解できるようにまとめてみたいと思います。
1. ステート分のボタンUI を作る
まずは必要なステート分のボタンUI を作ります。
今回はデジタル庁のデザインシステムからデザインデータをお借りしました。ステートは、Normal、Hover、Active、Focused、Disable があったので、こちらを使ってみます。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/ca4f6afeb3ad246908eecc276af2b51b-639x493.png)
2. それぞれをコンポーネント化する
5つあるボタンを、一つずつコンポーネント化していきます。
Figma の場合、コンポーネントになったUI は左上にひし形のマークが表示されます。これが親コンポーネントです。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/a409ed6b17c07a55e6b8a329a77ec582-639x493.png)
3. Variants として結合する
全てのステートを選択した状態で、Variants として結合します。こちらはステートの切り替えができるコンポーネントにするための下準備です。
下のイメージにある赤枠内のボタンを選択します。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/997a49a8aa694c4b2d0955460139c67d-740x374.png)
すべてのボタンが点線枠で囲われたら無事結合された状態です。もし枠線の中に入っていない場合、ステート管理の対象から外れてしまうので注意してください。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/a1b879e124feb62ea6b74e371aea9f35-740x475.png)
4. コンポーネントの Property を設定する
コンポーネントを Variants として結合したら、ステートの切り替えができるようにもう一つ下準備が必要です。右メニューの Properties から、Variant の詳細設定を行います。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/dd9bbb911b28211cf4bd970141d323b1-740x373.png)
![](https://wp.gaji.jp/wp-content/uploads/2023/08/9c5fba82d3060c1bca972180ad6e77d6-740x373.png)
上のイメージでは、Name の下の Values に Default しか表示がありません。これは初期状態でそうなっているため、ステートの切り替えができるようにステート分の名前を一つずつ入力していく必要があります。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/eba4521a6b9e248bf524eb3bceac5c96-740x373.png)
すべて入力すると、先ほどの Values に入力したステート名が表示されました。
これでステートの切り替えができるコンポーネントが完成です!
![](https://wp.gaji.jp/wp-content/uploads/2023/08/44b2d4f324e7c94fb42403619f55aba1-740x373.png)
5. ステートの切り替えができるか確認してみる
ちゃんとステートの切り替えができるコンポーネントになっているか、一度確認してみます。
その場合は親コンポーネント(ひし形のマークがあるもの)ではなく、親コンポーネントを複製された子コンポーネント( Instance と言います)を使います。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/9ad40c71e3c062137482b52c883d584c-740x373.png)
Instance を選択した状態で、右メニューの State から、Focused を選んでみます。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/43df6b917a3a0cfbad12e9dc19b89962-740x373.png)
上のイメージのように、指定したステートに表示が切り替わりましたか?
問題なく切り替わっていれば、ステート管理ができるコンポーネントになっています。
おわりに
ステートのパターンを持っておく場合、今回ご紹介した Variant を使うととても便利です。
Figma のコンポーネントには、他にもアイコンの表示・非表示の切り替えだったり、コンポーネントに含まれるテキスト要素の編集がしやすくなる設定方法もあるので、それはまた次の機会にまとめたいと思います。
![](https://wp.gaji.jp/wp-content/uploads/2023/08/ec7c71b4f3c6aa5996d8c64f3f826fdc-740x373.png)
Gaji-LaboはUIデザインでプロダクトを向上させます
「開発主導でつくられた現在のデザインに問題を感じているが、インハウスデザイナーがいない」
「インハウスデザイナーはいるが、メインプロジェクトにかかりきりで別件の改善に手が付けられない」
「独立した使い捨てのデザインではなく、既存のシステムとの連携もしっかり考えられるUIデザイナーを探している」
UIデザインに関わるお悩みごとをお持ちでしたら、まずは一度お気軽に Gaji-Labo にご相談ください。
オンラインでのヒアリングとフルリモートでのプロセス支援にも対応しています。
UIデザインの相談をする!