1: <?php
2: /*****************************************************************************************
3: * X2Engine Open Source Edition is a customer relationship management program developed by
4: * X2Engine, Inc. Copyright (C) 2011-2016 X2Engine Inc.
5: *
6: * This program is free software; you can redistribute it and/or modify it under
7: * the terms of the GNU Affero General Public License version 3 as published by the
8: * Free Software Foundation with the addition of the following permission added
9: * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10: * IN WHICH THE COPYRIGHT IS OWNED BY X2ENGINE, X2ENGINE DISCLAIMS THE WARRANTY
11: * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12: *
13: * This program is distributed in the hope that it will be useful, but WITHOUT
14: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15: * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16: * details.
17: *
18: * You should have received a copy of the GNU Affero General Public License along with
19: * this program; if not, see http://www.gnu.org/licenses or write to the Free
20: * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21: * 02110-1301 USA.
22: *
23: * You can contact X2Engine, Inc. P.O. Box 66752, Scotts Valley,
24: * California 95067, USA. or at email address contact@x2engine.com.
25: *
26: * The interactive user interfaces in modified source and object code versions
27: * of this program must display Appropriate Legal Notices, as required under
28: * Section 5 of the GNU Affero General Public License version 3.
29: *
30: * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31: * these Appropriate Legal Notices must retain the display of the "Powered by
32: * X2Engine" logo. If the display of the logo is not reasonably feasible for
33: * technical reasons, the Appropriate Legal Notices must display the words
34: * "Powered by X2Engine".
35: *****************************************************************************************/
36:
37: /**
38: * This is the model class for table "x2_widgets".
39: *
40: * @package application.models
41: * @property integer $id(auto-incremented)
42: * @property string $name
43: * @property integer $showPROFILE
44: * @property integer $adminALLOWS
45: * @property integer $showDASH
46: * @property integer $userID
47: * @property integer $position
48: */
49: class Widgets extends CActiveRecord{
50: /**
51: * Returns the static model of the specified AR class.
52: * @return Roles the static model class
53: */
54: public static function model($className=__CLASS__)
55: {
56: return parent::model($className);
57: }
58:
59: /**
60: * @return string the associated database table name
61: */
62: public function tableName()
63: {
64: return 'x2_widgets';
65: }
66:
67: /**
68: * @return array validation rules for model attributes.
69: */
70: public function rules()
71: {
72: // NOTE: you should only define rules for those attributes that
73: // will receive user inputs.
74: return array(
75: array('name,position', 'required'),
76: array('name', 'length', 'max'=>250),
77: array('id', 'safe'),
78: // The following rule is used by search().
79: // Please remove those attributes that should not be searched.
80: array('name,showPROFILE,adminALLOWS,showDASH,userID,position', 'safe', 'on'=>'search'),
81: );
82: }
83:
84: /**
85: * @return array relational rules.
86: */
87: public function relations()
88: {
89: // NOTE: you may need to adjust the relation name and the related
90: // class name for the relations automatically generated below.
91: return array(
92: );
93: }
94:
95: /**
96: * @return array customized attribute labels (name=>label)
97: */
98: public function attributeLabels()
99: {
100: return array(
101: 'name' => 'Name',
102: 'showPROFILE' => 'Show Profile',
103: 'adminALLOWS' => 'Admin Allows',
104: 'showDASH' => 'Show Dash',
105: 'userID' => 'User ID',
106: 'position' => 'Position',
107: );
108: }
109:
110: /**
111: * Retrieves a list of models based on the current search/filter conditions.
112: * @return CActiveDataProvider the data provider that can return the models based on the search/filter conditions.
113: */
114: public function search()
115: {
116: // Warning: Please modify the following code to remove attributes that
117: // should not be searched.
118:
119: $criteria=new CDbCriteria;
120:
121: $criteria->compare('name',$this->name);
122: $criteria->compare('showPROFILE',$this->showPROFILE,true);
123: $criteria->compare('adminALLOWS',$this->adminALLOWS,true);
124: $criteria->compare('showDASH',$this->showDASH,true);
125: $criteria->compare('userID',$this->userID,true);
126: $criteria->compare('position',$this->userID,true);
127: return new CActiveDataProvider(get_class($this), array(
128: 'criteria'=>$criteria,
129: ));
130: }
131: }
132: