今回は、Roundcubeプラグインとして、画面のあるプラグインの作り方を紹介します。
まず、初めにフォルダ構成は以下のようになります。
ソースの内容は以下のようになります。
sample.php
rc = rcmail::get_instance();
//ローカライズ対応
$this->add_texts('localization/');
//タスクとしてsampleを設定
$this->register_task('sample');
//タスクバーにボタンを追加
$this->add_button(array(
'command' => 'sample',
'label' => 'sample.sample',
), 'taskbar');
//sampleタスクの場合のみ、アクションのコールバックを登録
if($this->rc->task == 'sample'){
$this->register_action('index', array($this, 'index'));
$this->register_action('test', array($this, 'test'));
}
}
public function index(){
$this->rc->output->send('sample.index');
}
public function test(){
$this->rc->output->send('sample.test');
}
}
index.html
初期画面
test.html
テスト画面
ja_JP.inc
この状態でこのように動きます。
初期画面
data:image/s3,"s3://crabby-images/b6556/b6556b16a810504b6aee2575f052877b586b4b73" alt="img5"
テスト画面
data:image/s3,"s3://crabby-images/c8e18/c8e18a31d934cca9362201733da5afbdbe8f7954" alt="img4"
ここからはソースの説明になります。
①全てのリクエストは、プラグインクラスが受け付けます。
プラグインクラスとは、rcube_pluginを継承したクラスになります。
今回の場合、sampleクラスになります。
②タスクとアクション
Roundcubeにはタスクとアクションの概念があります。
1つのプラグインの中に1つのタスクがあり、複数のアクションがあるイメージになります。
今回の場合は、sampleタスクの中にindexアクションとtestアクションがある状態になります。
例えば、「http://roundcube.com/?_task=sample&_action=test」のようにアクセスすると
タスクはsampleで、アクションはtestという指定で動作します。
「http://roundcube.com/?_task=sample」このようなURLの場合
アクションは何もついていませんので、indexというアクションが自動的に付加されます。
③rcmailオブジェクト
$this->rc = rcmail::get_instance();
Roundcubeの様々な情報を持っているオブジェクトになります。
ここにタスクとアクションの情報も入っていますので、メンバ変数に保持します。
④コールバックの登録
あるアクションが指定されたときに、どのメソッドがコールされるかを登録します。
$this->register_action('index', array($this, 'index'));
この場合はindexというアクションが指定されたら、
$thisの中にあるindexメソッドをコールするという登録方法になります。
⑤テンプレート表示
$this->rc->output->send('sample.index');
上記のように記述することで、sampleタスク内にあるindex.htmlを表示するようにします。
data:image/s3,"s3://crabby-images/bb537/bb5379ffaf5d63b2d30aa6b7597d3102d375f76c" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/42b8c/42b8ccfabf0c1e57dea2662192c614aa119ed4fe" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/6dc33/6dc33a932e99659a9a46212b1e72a593f0454883" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/42cd1/42cd1da67c50922c2f9c0730cceb7ff5f35d70e7" alt="Share on tumblr tumblr"