File: /var/www/apklausos/application/models/Tutorial.php
<?php
/**
* This is the model class for table "{{tutorials}}".
*
* The following are the available columns in table '{{tutorials}}':
* @property integer $tid
* @property string $name
* @property string $title
* @property string $icon
* @property string $description
* @property integer $active
* @property string $permission
* @property string $permission_grade
* @property string $settings
*
* The following are the available model relations:
* @property TutorialEntry[] $tutorialEntries
*/
class Tutorial extends LSActiveRecord
{
/**
* @return string the associated database table name
*/
public function tableName()
{
return '{{tutorials}}';
}
/**
* @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(
array('name, description, active, permission, permission_grade', 'required'),
array('active', 'numerical', 'integerOnly' => true),
array('name, permission, permission_grade', 'length', 'max' => 128),
array('title', 'length', 'max' => 192),
array('icon', 'length', 'max' => 64),
// The following rule is used by search().
// @todo Please remove those attributes that should not be searched.
array('tid, name, description, active, permission, permission_grade', '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(
'tutorialEntryRelation' => array(self::HAS_MANY, 'TutorialEntryRelation', 'tid', 'together' => true),
);
}
/**
* @return array customized attribute labels (name=>label)
*/
public function attributeLabels()
{
return array(
'tid' => 'Tutorial ID',
'name' => 'Name',
'title' => 'Title',
'icon' => 'Icon',
'description' => 'Description',
'active' => 'Active',
'permission' => 'Permission',
'permission_grade' => 'Permission Grade',
);
}
public function getColumns()
{
$cols = array(
array(
'name' => 'tid',
'value' => '\'<input type="checkbox" name="id[]" class="action_selectthisentry" value="\'.$data->tid.\'" />\'',
'type' => 'raw',
'filter' => false
),
array(
'name' => 'name',
),
array(
'name' => 'title',
),
array(
'name' => 'description',
),
array(
'name' => 'active',
),
array(
'name' => 'settings',
'value' => '"<pre>".print_r(json_decode($data->settings,true),true)."</pre>"',
'type' => 'raw',
)
);
return $cols;
}
/**
* 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();
$criteria->compare('tid', $this->tid);
$criteria->compare('name', $this->name, true);
$criteria->compare('title', $this->title, true);
$criteria->compare('icon', $this->icon, true);
$criteria->compare('description', $this->description, true);
$criteria->compare('active', $this->active);
$criteria->compare('permission', $this->permission, true);
$criteria->compare('permission_grade', $this->permission_grade, true);
return new CActiveDataProvider($this, array(
'criteria' => $criteria,
));
}
/**
* @param string $tutorialName
* @return Tutorial
*/
public function findByName($tutorialName)
{
$defaultTutorials = LsDefaultDataSets::getTutorialData();
if (array_key_exists($tutorialName, $defaultTutorials)) {
$oTutorial = new Tutorial();
array_walk($defaultTutorials[$tutorialName], function ($attribute, $key) use (&$oTutorial) {
$oTutorial->setAttribute($key, $attribute);
});
return $oTutorial;
}
return $this->find('name=:name', [':name' => $tutorialName]);
}
public function getDefaultTutorials()
{
$aDefaultTutorials = LsDefaultDataSets::getTutorialData();
$result = [];
foreach ($aDefaultTutorials as $aDefaultTutorial) {
$oTutorial = new Tutorial();
$oTutorial->setAttributes($aDefaultTutorial);
$result[] = $oTutorial;
}
return $result;
}
public function getActiveTutorials()
{
$aTutorials = self::model()->findAll('active=1');
if (!empty($aTutorials)) {
return array_merge($aTutorials, $this->getDefaultTutorials());
}
return $this->getDefaultTutorials();
}
public function setFinished($iUserId)
{
$oMapTutUser = MapTutorialUsers::model()->find('uid=:uid AND tid=:tid', [':uid' => $iUserId, 'tid' => $this->tid]);
if ($oMapTutUser == null) {
$oMapTutUser = new MapTutorialUsers();
$oMapTutUser->setAttributes([
'uid' => $iUserId,
'tid' => $this->tid
]);
@$oMapTutUser->save();
}
}
public function getTutorialDataArray($tutorialName)
{
$aSteps = [];
if ($this->tid === null) {
$defaultEntries = LsDefaultDataSets::getTutorialEntryData();
$this->tid = $tutorialName;
foreach ($defaultEntries[$tutorialName] as $aTutorialMapEntry) {
$oTutorialEntry = new TutorialEntry();
$oTutorialEntry->setAttributes($aTutorialMapEntry, false);
$aSteps[] = $oTutorialEntry->getStepFromEntry();
}
} else {
$aTutorialEntryRelations = TutorialEntryRelation::model()->findAll('tid=:tid', [':tid' => $this->tid]);
foreach ($aTutorialEntryRelations as $oTutorialMapEntry) {
$oTutorialEntry = $oTutorialMapEntry->tutorialEntry;
$aSteps[] = $oTutorialEntry->getStepFromEntry();
}
}
$aTutorialData = json_decode($this->settings, true);
$aTutorialData['steps'] = $aSteps;
$aTutorialData['tid'] = $this->tid;
return $aTutorialData;
}
/**
* 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 Tutorial the static model class
*/
public static function model($className = __CLASS__)
{
/** @var Tutorial $model */
$model = parent::model($className);
return $model;
}
}