Created
September 7, 2013 04:08
-
-
Save naotawool/6472758 to your computer and use it in GitHub Desktop.
Gii拡張版。
Yii 1.1.14 をベースに拡張。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* This is the template for generating the model class of a specified table. | |
* - $this: the ModelCode object | |
* - $tableName: the table name for this class (prefix is already removed if necessary) | |
* - $modelClass: the model class name | |
* - $columns: list of table columns (name=>CDbColumnSchema) | |
* - $labels: list of attribute labels (name=>label) | |
* - $rules: list of validation rules | |
* - $relations: list of relations (name=>relation declaration) | |
*/ | |
?> | |
<?php echo "<?php\n"; ?> | |
/** | |
* This is the model class for table "<?php echo $tableName; ?>". | |
* | |
* The followings are the available columns in table '<?php echo $tableName; ?>': | |
<?php foreach($columns as $column): ?> | |
* @property <?php echo $column->type.' $'.$column->name.' '.$column->comment."\n"; ?> | |
<?php endforeach; ?> | |
<?php if(!empty($relations)): ?> | |
* | |
* The followings are the available model relations: | |
<?php foreach($relations as $name=>$relation): ?> | |
* @property <?php | |
if (preg_match("~^array\(self::([^,]+), '([^']+)', '([^']+)'\)$~", $relation, $matches)) | |
{ | |
$relationType = $matches[1]; | |
$relationModel = $matches[2]; | |
switch($relationType){ | |
case 'HAS_ONE': | |
echo $relationModel.' $'.$name."\n"; | |
break; | |
case 'BELONGS_TO': | |
echo $relationModel.' $'.$name."\n"; | |
break; | |
case 'HAS_MANY': | |
echo $relationModel.'[] $'.$name."\n"; | |
break; | |
case 'MANY_MANY': | |
echo $relationModel.'[] $'.$name."\n"; | |
break; | |
default: | |
echo 'mixed $'.$name."\n"; | |
} | |
} | |
?> | |
<?php endforeach; ?> | |
<?php endif; ?> | |
*/ | |
class <?php echo $modelClass; ?> extends <?php echo $this->baseClass."\n"; ?> | |
{ | |
/** | |
* @return string the associated database table name | |
*/ | |
public function tableName() | |
{ | |
return '<?php echo $tableName; ?>'; | |
} | |
/** | |
* @return array validation rules for model attributes. | |
*/ | |
public function rules() | |
{ | |
// NOTE: you should only define rules for those attributes that | |
// will receive user inputs. | |
return array( | |
<?php foreach($rules as $rule): ?> | |
<?php echo $rule.",\n"; ?> | |
<?php endforeach; ?> | |
// The following rule is used by search(). | |
// @todo Please remove those attributes that should not be searched. | |
array('<?php echo implode(', ', array_keys($columns)); ?>', 'safe', 'on'=>'search'), | |
); | |
} | |
/** | |
* @return array relational rules. | |
*/ | |
public function relations() | |
{ | |
// NOTE: you may need to adjust the relation name and the related | |
// class name for the relations automatically generated below. | |
return array( | |
<?php foreach($relations as $name=>$relation): ?> | |
<?php echo "'$name' => $relation,\n"; ?> | |
<?php endforeach; ?> | |
); | |
} | |
/** | |
* @return array customized attribute labels (name=>label) | |
*/ | |
public function attributeLabels() | |
{ | |
return array( | |
<?php foreach($labels as $name=>$label): ?> | |
<?php echo "'$name' => '$label',\n"; ?> | |
<?php endforeach; ?> | |
); | |
} | |
/** | |
* Retrieves a list of models based on the current search/filter conditions. | |
* | |
* Typical usecase: | |
* - Initialize the model fields with values from filter form. | |
* - Execute this method to get CActiveDataProvider instance which will filter | |
* models according to data in model fields. | |
* - Pass data provider to CGridView, CListView or any similar widget. | |
* | |
* @return CActiveDataProvider the data provider that can return the models | |
* based on the search/filter conditions. | |
*/ | |
public function search() | |
{ | |
// @todo Please modify the following code to remove attributes that should not be searched. | |
$criteria=new CDbCriteria; | |
<?php | |
foreach($columns as $name=>$column) | |
{ | |
if($column->type==='string') | |
{ | |
echo " \$criteria->compare('$name',\$this->$name,true);\n"; | |
} | |
else | |
{ | |
echo " \$criteria->compare('$name',\$this->$name);\n"; | |
} | |
} | |
?> | |
return new CActiveDataProvider($this, array( | |
'criteria'=>$criteria, | |
)); | |
} | |
<?php if($connectionId!='db'):?> | |
/** | |
* @return CDbConnection the database connection used for this class | |
*/ | |
public function getDbConnection() | |
{ | |
return Yii::app()-><?php echo $connectionId ?>; | |
} | |
<?php endif?> | |
/** | |
* Returns the static model of the specified AR class. | |
* Please note that you should have this exact method in all your CActiveRecord descendants! | |
* @param string $className active record class name. | |
* @return <?php echo $modelClass; ?> the static model class | |
*/ | |
public static function model($className=__CLASS__) | |
{ | |
return parent::model($className); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment