Link.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: xiaofeng
  5. * Date: 2018/3/4
  6. * Time: 上午9:40
  7. */
  8. namespace common\models;
  9. //use yii\db\ActiveRecord;
  10. //use yii\behaviors\TimestampBehavior;
  11. //use Yii;
  12. class Link extends Common
  13. {
  14. // public $setDel = 1;
  15. // public function behaviors()
  16. // {
  17. // return [
  18. // [
  19. // 'class' => TimestampBehavior::className(),
  20. // 'attributes' => [
  21. // # 创建之前
  22. // ActiveRecord::EVENT_BEFORE_INSERT => ['create_at', 'update_at'],
  23. // # 修改之前
  24. // ActiveRecord::EVENT_BEFORE_UPDATE => ['update_at']
  25. // ],
  26. // #设置默认值
  27. // 'value' => $_SERVER['REQUEST_TIME']
  28. // ]
  29. // ];
  30. // }
  31. public function rules()
  32. {
  33. return [
  34. [['title','url','city','linktype'],'required','message'=>'{attribute}不能为空'],
  35. [['city','linktype'],'number'],
  36. ['state','default','value'=>1],
  37. ['state','in','range'=>[1,2]],
  38. ['del','in','range'=>[1,2]],
  39. ];
  40. }
  41. public function attributeLabels()
  42. {
  43. return [
  44. 'title'=>'标题',
  45. 'url'=>'链接',
  46. 'city'=>'区域',
  47. 'linktype'=>'位置'
  48. ];
  49. }
  50. public function Authenticator($input)
  51. {
  52. $this->load($input,'');
  53. if(!$this->validate()) return $this->errors;
  54. return $this;
  55. }
  56. public function FindById($id)
  57. {
  58. return self::findOne($id);
  59. }
  60. public function getList($data)
  61. {
  62. $query = $this->QueryFind();
  63. $query->select(['pfg_link.*','pfg_category_city.city_name','pfg_sysmenu_q.name as sys_name']);
  64. $query = $this->LeftJoinWhere($query);
  65. $query = $this->LeftJoinTable($query);
  66. if(!empty($data['page']))
  67. {
  68. $query->offset = ($data['page'] - 1) * $data['limit'];
  69. $query->limit = $data['limit'];
  70. }
  71. return $query->orderBy('create_at')->asArray()->all();
  72. }
  73. public function Total()
  74. {
  75. $query = $this->QueryFind();
  76. $query = $this->LeftJoinWhere($query);
  77. $query = $this->LeftJoinTable($query);
  78. return $query->count();
  79. }
  80. private function LeftJoinWhere($query)
  81. {
  82. $query->andWhere(['pfg_link.del'=>$this->setDel]);
  83. return $query;
  84. }
  85. private function LeftJoinTable($query)
  86. {
  87. $query->leftJoin('pfg_category_city','pfg_link.city = pfg_category_city.id');
  88. $query->leftJoin('pfg_sysmenu_q','pfg_link.linktype = pfg_sysmenu_q.id');
  89. return $query;
  90. }
  91. private function QueryFind()
  92. {
  93. return self::find();
  94. }
  95. }