複写して新規作成
CRUD 操作に「複写して新規作成」という操作を追加すると便利です。
機能的には、既存のエントリーの内容をコピーして、新規作成のフォームにペーストするものです。少し内容を変えただけの新規エントリーを登録したい場合に重宝します。
「複写して新規作成」は、Gii が自動生成した CRUD のコードをほんの少し拡張するだけで実装することが可能です。
1) コントローラに、モデルのデータを複製するメソッドを追加。
public function duplicateModel($id)
{
$model = $this->loadModel($id);
// 新規エントリーとするために、データを部分的にクリアする
$model->id = null; // PK をクリア ... たいていの場合に必須
$model->foo = null; // 例
$model->bar = null; // 例
.... // 何をクリアすべきかは、モデルの設計によって異なる
// クリア操作は、モデルクラスでやる方が良いかも、、、
$model->isNewRecord = true; // 新規レコードとする ... 必須
return $model;
}
2) コントローラの actionCreate() メソッドを修正して、PK をパラメータとして取るようにする。
public function actionCreate($id = null)
{
$model = null;
if ($id === null || isset($_POST['FooBar']))
$model = new FooBar;
else
$model = $this->duplicateModel($id);
// AJAX validation
$this->performAjaxValidation($model);
if (isset($_POST['FooBar']))
{
$model->attributes = $_POST['FooBar'];
if ($model->save())
$this->redirect(array('view', 'id'=>$model->id));
}
$this->render('create',array(
'model' => $model,
));
}
引数 `$id` は、デフォルト値として `null` を取ります。
`$id` が null の場合は、従来同様、"create" のアクションとして機能し、`$id` に有効な値が入っている場合は、「複写して新規作成」のアクションとして機能します。
3) ビュー・ファイルで、「複写して新規作成」を呼び出すリンクを作る。
例えば、view.php で、
// views/FooBar/view.php
....
<?php echo CHtml::link('複写して新規作成', array('create', 'id'=>$model->id)); ?>
....
または、admin.php で、
// views/FooBar/admin.php
....
$this->widget('zii.widgets.grid.CGridView', array(
'id' => 'foo-bar-grid',
'dataProvider' => $model->search(),
'filter' => $model,
'columns' => array(
'foo',
'bar',
....
array(
'class' => 'CButtonColumn',
),
array(
'header' => '複写して新規作成',
'type' => 'raw',
'value' => 'CHtml::link("複写して新規作成", array("create", "id"=>$data->id))',
),
),
));
たったこれだけです。お試しあれ。