Google Chart Toolsを使ってサイトマップを描こう!

こんにちは!最近寒いですが、みなさんいかがお過ごしでしょうか。
クリスマスも近いということで、クリスマスツリー→ツリー→組織ツリー→組織図!エンジニアのクリスマスはツリーですね!
今回は、Org Chartを使ってサイトマップを描いてみたいと思います。

1. Google Chart Toolsって?

Googleが提供している、グラフや表を簡単に作成するAPIです。(Google Chart Tools
チャートギャラリーには、様々なグラフがギャラリー形式で並んでいます。
中には、メーターや世界地図、札束積み上げグラフ(?)など、ユニークなグラフもあります。
Code Playgroundでは、実際にコードを書いて即時実行しながら、様々なチャートで遊ぶことができます。

今回は、この中からOrg Chart(組織図)を使って、サイトマップを描いてみます。

2. サイトマップの作成

Org Chartでは、こんなかんじでサイトマップが描けます。

どんなコードかというと、こちら!


<html>
  <head>
    <script type='text/javascript' src='https://www.google.com/jsapi'></script>
    <script type='text/javascript'>
      var chart;
      // visualizationを読み込む
      google.load('visualization', '1', {packages:['orgchart']});
      google.setOnLoadCallback(drawChart);
  
      // チャートの設定と描画
      function drawChart() {
        var data = new google.visualization.DataTable();  // ---(1-1)
        data.addColumn('string', 'Name');                 // ---(1-2)
        data.addColumn('string', 'Parent');               // ---(1-3)
        data.addColumn('string', 'ToolTip');              // ---(1-4)
  
        // ---(2)
        data.addRows([
          [{v:'top', f:'トップページ'}, '', 'tooltip'], // ---(3)
            [{v:'company', f:'会社紹介'}, 'top', ''],
              [{v:'company-index', f:'ご挨拶'}, 'company', ''],
              [{v:'about', f:'会社概要'}, 'company', ''],
            [{v:'system', f:'Webシステム構築'}, 'top', ''],
            [{v:'school', f:'PHPスクール'}, 'top', ''],
              [{v:'course', f:'各コースの概要と紹介'}, 'school', ''],
                [{v:'course1', f:'PHP基礎編'}, 'course', ''],
                [{v:'course2', f:'PHP中級実務編'}, 'course', ''],
                [{v:'orientation', f:'講座説明会(無料)のご案内'}, 'school', ''],
              [{v:'business', f:'製品/サービス'}, 'top', ''],
              [{v:'phppro', f:'PHPプロ!'}, 'business', ''],
              [{v:'phpbiz', f:'PHPbiz'}, 'business', ''],
        ]);
  
        // (4)
        chart = new google.visualization.OrgChart(document.getElementById('chart_div'));
        chart.draw(data, {allowHtml: true,} );
      }
    </script>
  </head>
  <body>
    <div id='chart_div'></div>
  </body>
</html>

上記のコードが基本形です。まず、(1)についてご説明します。
(1-1)では、DataTableのインスタンスを作成します。
(1-2)〜(1-4)では、そのDataTableにカラムを3つ追加しています。
(1-4)でツールチップカラムを追加すると、そのノード(青いボックス)にマウスを合わせた時、ぺろっとツールチップが表示され、そこに表示する文字列を設定することができます。
データベースでいうと、addColumnでカラムを作るというイメージです。


var data = new google.visualization.DataTable();  // インスタンス作成
data.addColumn('string', 'Name');                 // はじめのカラム:ノードの名前
data.addColumn('string', 'Parent');               // 次のカラム:親ノードの名前
data.addColumn('string', 'ToolTip');              // 最後のカラム:ツールチップ

つまり、ノードと親ノードだけ最低でも設定すればよく、ツールチップは付加的なものということです。

次に、(2)でデータを追加していきます。
data.addRowsは、データベースでいうINSERTに近いイメージです。今回のソースでは、ノードの親子関係がわかりやすいようインデントをつけました。

(3)では、実際にデータを定義しています。
はじめの要素であるノードの名前をキーと値の配列にすることで、データのIDと表面に出る文字列を別々に定義できます。
2つめのParentカラムを空文字にすることで、親ノードがないもの(ルートノード)を定義できます。
3つめのToolTipには、マウスを合わせた際のツールチップで表示する文字列を定義します。


[{v:'top', f:'トップページ'}, '', 'tooltip'],  // ルートノード:一意なキーはtop,  表示するのは「トップページ」
  [{v:'company', f:'会社紹介'}, 'top', ''],    // キーcompany、「会社紹介」というノードは、親のキーが「top」

こうして、ノードにNameを振り、親ノードのNameをParentに指定していくことで、どんどんツリーをぶら下げていくことができます。
キーと表示する文字列が同じ場合は、下記のように簡単に書けます。


['top' '', 'tooltip'],  // ルートノード:キーはtopで、表示もtopとなる。
  ['company', 'top', ''],    // キーはcompanyで、親のキーはtop

最後に、(4)で、ドキュメント内のchar_divというDIVに、チャートを書き込みます。
描かれたOrg ChartはHTMLのTable要素で書かれています。


chart = new google.visualization.OrgChart(document.getElementById('chart_div'));
chart.draw(data, {allowHtml: true,} );

これで、基本的なOrgChartを描くことができます!

3. もっと!Org Chart

これまでの説明では、Org Chartの基本的な部分について触れました。
ここからは、もっとOrgChartを豊かにするためのオプションについてご説明します。

CSSでデザインを変えたい

CSSでまとめてデザイン変更したいですね?調べておきました。


  .google-visualization-orgchart-node
    ノードに付いている基本的なクラス
  .google-visualization-orgchart-node-medium
    後述する、ノードの大きさによるクラス。
    small, medium, largeがあるので、末尾を変えてください。
  .google-visualization-orgchart-nodesel
    ノードをクリックしたときに適用されるクラス。

 

ノードのスタイルを変更したい

ノード全体のスタイルならばCSSで変更できますが、このノードだけ変更したい!ということはないでしょうか。
例えば、ルートノードだけピンクにしたい…とか。
そういった場合、クラスはどれも同じなため、CSSで「このノードだけ」「こうしたい」と変更するのはなかなか難しいですね。

これで、ノードを指定してスタイルを変更できます!


data.setRowProperty(2, 'style', 'background:#ffe5ff;border-color:#ff8989;');
data.setRowProperty(1, 'selectedStyle', 'background:#FF0000;');

第1引数は、ノードの番号です。これは、addRowsされた順番に0から振られている番号です。
つまり、先ほどのコードでいうと、0は「トップページ」、1は「会社紹介」、2は「ご挨拶」というような指定の方法です。

第2引数は「style」か、「selectedStyle」を指定します。
style はそのノードのスタイル、selectedStyleはクリックしたときのスタイルです。

第3引数には、インラインスタイルを入れてください。

このsetRowPropertyは、addRowsからdrawの間に入れてください。
データを定義する→データにスタイルを適用する→チャートを描くという流れだからです。

drawするときのプロパティを指定したい

drawするときに、プロパティを指定することができます。


chart.draw(data, {
  allowHtml: true,            // ノードのHTMLを許可するか。Default=false
  size: 'medium',             // セルの大きさ。Default='medium'
  allowCollapse: false,       // ダブルクリックしてどうなるか。Default=false
  nodeClass: 'asial',         // ノードのクラス名
  selectedNodeClass: 'asial'  // クリックされたとき(Selected)のクラス名
});

allowHtmlは、ノードの表示する文字列内にHTMLを含めてもよいか設定する項目です。
デフォルトはfalse(許可しない)ですが、trueにすると以下のように、HTMLを含めることができます。


[{v:'top', f:'<span style="color: #FF0000;">トップページ</span>'}, '', 'tooltip'],

sizeは、ノードのサイズです。small, medium, largeから選ぶことができます。デフォルトはmediumです。
ここで選択したノードのサイズが、クラス名としてTD要素に適用されます。(.google-visualization-orgchart-node-mediumなど)

allowCollapseは、ノードをダブルクリックしたときに表示・非表示アクションをさせるかどうか設定する項目です。
デフォルトはfalse(常に表示)で、ノードは全部展開されています。
trueにすると、子ノードがあるノードをダブルクリックしたときに、子ノードを隠すようなアクションをします。
もう一度ノードをダブルクリックすると子ノードを展開します。

nodeClassは、各ノードのクラス名です。
デフォルトのクラス名でなく、独自のクラスが使いたいときに利用します。
同様に、selectedNodeClassも、クリックされたときのクラス名となります。

おわりに

この他にもOrg Chartでは、イベントの取得や様々なメソッドなどが提供されています。
Chart ToolsにはOrg Chart以外にも魅力的なチャートがたくさんありますから、ぜひ使ってみてください!