<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <meta http-equiv="Content-Script-Type" content="text/javascript" />
    <meta http-equiv="Content-Style-Type" content="text/css" />
    <title>ページタイプを追加するには</title>
    <link rel="stylesheet" href="/css/style.css" type="text/css" media="all" />
    
    
  </head>
  <body>
    <div class="header">
      <div id="pane.left-header" class="pane left">
        <div id="org.seasar.kvasir.cms.toolbox.customPop-8" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <div class="body"><div class="wiki">
<ul>
<li><a href="/" class="pageNotFound">（サイトトップ）</a></li>
<li><a href="/download">ダウンロード</a></li>
<li><a href="/news/" class="pageNotFound">新着情報</a></li>
<li><a href="/doc/" class="pageNotFound">ドキュメント</a></li>
</ul>
</div>
</div>
        </div>
      </div>
      <div id="pane.right-header" class="pane right">
        <div id="org.seasar.kvasir.cms.toolbox.loginPop-1" class="pop org.seasar.kvasir.cms.toolbox.loginPop">
          <div class="body">
<form method="post" action="/plugins/toolbox/login.do/doc/plugin-dev/addPageType">
    <div class="row">
      <span class="label">Name</span>
      <span class="textinput"><input type="text" name="name" size="12" value="" /></span>
    </div>
    <div class="row">
      <span class="label">Password</span>
      <span class="textinput"><input type="password" name="password" size="12" value="" /></span>
    </div>
    <div class="row">
      <span class="submit"><input type="submit" value="Login" /></span>
    </div>
</form>
</div>
        </div><div id="org.seasar.kvasir.cms.pop.loginUserPop-1" class="pop org.seasar.kvasir.cms.pop.loginUserPop">
          <div class="body"></div>
        </div>
      </div>
    </div>
    <div class="page-frame">
      <div id="pane.left-sidebar" class="pane sidebar-frame sidebar subcontent">
        <div id="org.seasar.kvasir.cms.toolbox.searchPop-1" class="pop org.seasar.kvasir.cms.toolbox.searchPop">
          <h2 class="title">Search</h2>
          <div class="body"><form class="simple" method="get" action="/plugins/toolbox/search.do">
  <input type="text" name="query" size="12" />
  <input type="submit" value="Go!" />
</form>
</div>
        </div><div id="org.seasar.kvasir.cms.toolbox.customPop-6" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <h2 class="title">リンク</h2>
          <div class="body"><div class="wiki">
<ul>
<li><a href="http://www.seasar.org/">The Seasar Project</a></li>
<li>関連プロダクト</li>
<ul>
<li><a href="http://www.skirnir.net/product/freyja/">Freyja</a></li>
<li><a href="http://www.skirnir.net/product/rst/">RST</a></li>
<li><a href="http://www.skirnir.net/product/xom/">xom</a></li>
<li><a href="http://ymir.sandbox.seasar.org/">Ymir</a></li>
<li><a href="http://cms.sandbox.seasar.org/">CMS Project</a></li>
</ul>
</ul>
</div>
</div>
        </div><div id="org.seasar.kvasir.cms.toolbox.customPop-5" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <h2 class="title">メニュー</h2>
          <div class="body"><div class="wiki">
<ul>
<li><a href="/" class="pageNotFound">（サイトトップ）</a></li>
<li><a href="/download">ダウンロード</a></li>
<li><a href="/news/" class="pageNotFound">新着情報</a></li>
<li><a href="/doc/user">サイト管理者マニュアル</a></li>
<ul>
<li><a href="/doc/user/install">はじめの一歩</a></li>
<li><a href="/doc/user/database">データベースの設定</a></li>
<li><a href="/doc/user/faq">FAQ</a></li>
</ul>
<li><a href="/doc/plugin-dev">プラグイン開発者マニュアル</a></li>
<ul>
<li><a href="/doc/plugin-dev/faq">FAQ</a></li>
</ul>
<li><a href="/doc/kvasir-dev">Kvasir/Sora開発者マニュアル</a></li>
<li><a href="/doc/ref">リファレンスマニュアル</a></li>
<li><a href="https://ml.seasar.org/mailman/listinfo/kvasir-user">メーリングリストに参加するには</a></li>
<li><a href="https://www.seasar.org/issues/browse/KVASIR">既知の不具合を閲覧する・不具合を報告する</a></li>
<li><a href="https://www.seasar.org/svn/sandbox/kvasir/">SVNリポジトリ</a></li>
<li><a href="http://svn.seasar.org/browse/?root=sandbox.kvasir">SVNリポジトリを閲覧</a></li>
<li><a href="/doc/environments">動作確認状況</a></li>
</ul>
</div>
</div>
        </div><div id="org.seasar.kvasir.cms.toolbox.customPop-3" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <h2 class="title">協力者募集！</h2>
          <div class="body"><div class="wiki">
<p>プラグイン作成、サイトテンプレート（HTML、CSS）作成、ドキュメント作成など、開発に協力して頂ける方を募集しています！</p>
<p>協力して下さる方は<a href="https://ml.seasar.org/mailman/listinfo/kvasir-user">kvasir-userメーリングリスト</a>にご連絡下さい。大勢の方のご協力をお待ちしています。</p>
</div>
</div>
        </div>
      </div>
      <div id="pane.main" class="main pane">
      
        <div id="org.seasar.kvasir.cms.toolbox.breadcrumbsPop-1" class="pop org.seasar.kvasir.cms.toolbox.breadcrumbsPop">
          
          <div class="body"><ul>
  <li class="first"><a href="/">(TOP)</a></li><li><a href="/doc">ドキュメント</a></li><li><a href="/doc/plugin-dev">プラグイン開発者マニュアル</a></li><li>ページタイプを追加するには</li>
</ul>
</div>
        </div><div id="org.seasar.kvasir.cms.pop.contentPop-1" class="pop org.seasar.kvasir.cms.pop.contentPop">
          <h2 class="title">ページタイプを追加するには</h2>
          <div class="body">
<ul class="information">
  
  <li>2010-04-17 00:10 更新</li>
</ul>
<div class="content"><div class="wiki">
<p>ページタイプを追加するために必要な作業は以下のとおりです。</p>
<ul>
<li>org.seasar.kvasir.page.Pageインタフェースのサブインタフェースと実装クラスを作成する</li>
<li>org.seasar.kvasir.page.PageMoldクラスのサブクラスを作成する</li>
<li>org.seasar.kvasir.page.type.PageTypeインタフェースの実装クラスを作成する</li>
<li>ページタイプのためのアイコンを作成する</li>
<li>pageTypes拡張ポイントにプラグインするためのエントリをplugin.xmlに追加する</li>
<li>plugin.diconに作成したPageTypeコンポーネントを追加する</li>
</ul>
<p>例としてcom.exampleプラグインで「glossary」（用語集）というページタイプを追加する場合について説明します。</p>
<h3>org.seasar.kvasir.page.Pageインタフェースのサブインタフェースと実装クラスを作成する</h3>
<p>Kvasir/Soraの中で用語集ページタイプのページオブジェクトを扱うためのインタフェースとして、com.example.pageType.Glossaryインタフェースを作成します。GlossaryインタフェースはPageインタフェースのサブインタフェースとします。</p>
<pre>public interface Glossary extends Page {
    String TYPE = &quot;glossary&quot;;
}
</pre>
<h3>org.seasar.kvasir.page.PageMoldクラスのサブクラスを作成する</h3>
<p>用語集ページを新規作成するための情報を指定するためのクラスとして、com.example.pageType.GlossaryMoldクラスを作成します。</p>
<p>GlossaryMoldインタフェースはPageMoldクラスのサブクラスとします。</p>
<pre>public class GlossaryMold extends PageMold {
    public GlossaryMold() {
        super.setType(Glossary.TYPE);
    }

    public GlossaryMold(String name) {
        this();
        setName(name);
    }

    @Override
    public PageMold setType(String type) {
        throw new UnsupportedOperationException();
    }
}
</pre>
<h3>org.seasar.kvasir.page.type.PageTypeインタフェースの実装クラスを作成する</h3>
<p>作成するページタイプのメタ情報をKvasir/Soraに伝えるためのクラスとして、com.example.pageType.GlossaryPageTypeクラスを作成します。GlossaryPageTypeクラスはPageTypeインタフェースの実装クラスとします。ベースクラスとしてorg.seasar.kvasir.page.type.AbstractPageTypeを利用することができます。</p>
<pre>public class GlossaryPageType extends AbstractPageType {
    public static final String ID = Glossary.TYPE;

    public String getId() {
        return ID;
    }

    public Class&lt;? extends Page&gt; getInterface() {
        return Glossary.class;
    }

    public Page wrapPage(Page page) {
        return new GlossaryImpl(page);
    }

    public PageMold newPageMold() {
        return new GlossaryMold();
    }

    public String convertFieldToPropertyName(String field) {
        return null;
    }

    public boolean isNumericField(String field) {
        return false;
    }
}
</pre>
<h3>ページタイプのためのアイコンを作成する</h3>
<p>追加するページタイプをWebサイト上で視覚的に表現するためのアイコンを作成してsrc/main/plugin/conf/glossary/ディレクトリに配置します。アイコンとしては可視状態を表わすicon.gifと、不可視状態を表わすicon_concealed.gifを作成します。</p>
<p>アイコンの名前と画像フォーマットは任意ですが、不可視状態を表わすアイコンの名前から拡張子を除いた部分は可視状態を表わすアイコンの名前から拡張子を除いた部分に「_concealed」を付与したものである必要があります。</p>
<p>アイコンの大きさは16×16として下さい。</p>
<h3>pageTypes拡張ポイントにプラグインするためのエントリをplugin.xmlに追加する</h3>
<p>com.exampleプラグインのplugin.xmlにorg.seasar.kvasir.page.pageTypes拡張ポイントにglossaryページタイプをプラグインするためのエントリを追加します。</p>
<pre>&lt;extension point=&quot;org.seasar.kvasir.page.pageTypes&quot;&gt;
  &lt;page-type id=&quot;glossaryPageType&quot; icon-resource-path=&quot;conf/glossary/icon.gif&quot; /&gt;
&lt;/extension&gt;
</pre>
<p>icon-resource-path属性の値には作成した可視状態を表わすアイコンのプラグインディレクトリ相対パスを指定します。</p>
<h3>作成したPageTypeコンポーネントをplugin.diconに追加する</h3>
<p>src/main/plugin/conf/plugin.diconにGlossaryPageTypeコンポーネントのためのエントリを追加します。</p>
<pre>&lt;component name=&quot;glossaryPageType&quot; class=&quot;com.example.pageType.GlossaryPageType&quot; /&gt;
</pre>
<p>name属性はplugin.xmlに追加したpage-typeエレメントのid属性と同じ値にするようにして下さい。</p>
<p>以上でページタイプが追加されます。</p>
</div>
</div>
</div>
        </div><div id="org.seasar.kvasir.cms.toolbox.menuPop-2" class="pop org.seasar.kvasir.cms.toolbox.menuPop">
          
          <div class="body">
<div class="document-list" style="margin-top:4ex">
  
</div>
</div>
        </div>
      
    </div>
    </div>
    <div class="footer-delimiter"></div>
    <div id="pane.footer" class="pane footer">
      <div id="org.seasar.kvasir.cms.pop.poweredByPop-1" class="pop org.seasar.kvasir.cms.pop.poweredByPop">
        <div class="body">Powered by Kvasir/Sora</div>
      </div>
    </div>
  </body>
</html>
