トレタ Advent Calendar 2017の12日目の記事です。
トレタでiOSエンジニアをやっている @y_koh です。
今日はiPadアプリでいつも頭を悩ませる「ヘルプ」について書いてみます。
設定難しい問題
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2Feedbac00-2243-136a-b934-9ea974ef28c5.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=0cf99ad58b385e323502362ec74193d1)
さて、これはトレタの設定画面なのですが、ぱっと見操作に迷うようなところは無いと思います。でもそれぞれの項目を設定することでどうなるのかってわからないですよね。
現状はカスタマーサクセス部門が導入説明会で丁寧に教えているので、特に問題にはなっていません。ただ、今後導入店舗数が増え続けていく状況で全てのお客様に対して手取り足取りやっていくことは現実的ではなくなってきました。
やっぱりヘルプが必要なのでは?
- ヘルプ?そんなもんデザインの負けでしょ?
- そうかもしれません。でも負けたとしてもちゃんと使えてなければ何の意味もないと思うんですよね
- デザインで解決できることはもちろんするとして、それを補完するためにヘルプが必要なことはあるんじゃないかなぁと思います
ヘルプに必要なこと
- 邪魔にならないこと
- 必要な時に必要な情報を見つけられること
- 今やっている作業を中断せずに確認できること
-
継続的にメンテナンスできること
- これ地味に大事なところです
みんなどうしてる?
悩んだらまずはApple標準アプリを確認してみましょう。
Appleアプリ
GarageBand
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2Fd8299a58-e979-9dab-0117-147841397b34.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=9a6c2093f7caef245257f97bc27cf26d)
disclosureタップした箇所によって表示するヘルプも変わります。
ここでは上の「コントロールバーの詳細情報」をタップしてます。
画面遷移が少なく、操作するものがだいたい同じ位置にとどまっているものはこのタイプのヘルプが採用されています。
iMovieも同様でした。
Keynote
Keynoteでは画面上にコントローラが少ないので、先程のようにオーバーレイするものは無かったです。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2F55d6f106-7e22-a118-8f93-9ea04f6c7b53.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=067f3d9d0b0b751d333de602f110c6f1)
Keynote、Pages、Numbersはこちらのパターンでした。
結構ちゃんとトーン揃えてるんだなぁという感じですよね。
実はこれHelpKitというprivateフレームワークでした。
HelpKit
何でこれに気づいたかというと、リンクを何気なーくドラッグしたら普通にフレームワーク名が見えました(^_^;)
Helpの内容はウェブベースになっていて、リアルタイムにメンテナンス可能になっています。
ベンダーアプリ
Dropbox
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2F984be54a-3178-f4f9-da8e-65e7c215ecd6.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=515cb3a9f8dfc02c649a7faf61947d21)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2F319e5df3-e2f6-ede1-d6c5-261e19b336d5.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=2ba4cbc467138dc3b8978e8f6f44ac14)
これすごくいいなと思いました。既にあるウェブベースのHelpをアプリ上ではSFSafariViewControllerを使ってモーダルで表示させるだけです。
(ちょっと下の方にプランとかへのリンクがあるのが大丈夫なのか気になりますが…)
これならメンテするときも、元のヘルプを更新するだけで良いですね。
トレタアプリでやるとしたら…
※あくまでお試しで現状プロダクションに載せる予定は無いです
完全にジャストアイデアで、Issueではなくいきなり打ち手に飛んでますが、
こんな感じでそれぞれにヘルプボタンを置いて、該当するヘルプページを表示するのはどうでしょう。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2Fc08f3fc1-73f6-4641-646b-a822c1ca7d2f.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=584f7073b16d536363200f85b7b43196)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2F32468078-475d-effd-3def-3f4c33b2b04d.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=d4580b5f76688965b7e45d0e013c0136)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F2569%2F67d8d309-a5e3-a475-9862-ab6970c2ff6a.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=f54cd2f63ed889b876f7c8659854db77)
ヘルプは既存のものを使っていますし、SFSafariViewControllerは全画面ではないので、後ろの画面も見えて何をしていたかを忘れずにすみます。(横長になっているのは現状のヘルプページの関係で狭いとかなり見づらかったためです)
ちなみに設定画面内の他の画面にも設置してみたのですが、共通化部分に追加することが出来たので全体で50行くらいで実装することが出来ました。これくらいのコスト感で出来るなら結構良いのでは?と思ったりしてます。
まとめ
- ヘルプは悪ではない
- ただし、よく考えないとメンテされずに放置され負の遺産になる
- SFSafariViewControllerで既存ヘルプを表示するのはコスト低めでおすすめ