Like.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. namespace Act\Lib;
  3. use Dever;
  4. class Like
  5. {
  6. # 获取评论列表
  7. public function get($id, $type)
  8. {
  9. $where['type'] = $type;
  10. $where['data_id'] = $id;
  11. $data = Dever::db('act/comment')->getAll($where);
  12. if ($data) {
  13. foreach ($data as $k => $v) {
  14. $user = Dever::db('passport/api')->info($v['uid']);
  15. $data[$k]['username'] = $user['username'];
  16. $data[$k]['avatar'] = $user['avatar'];
  17. }
  18. }
  19. return $data;
  20. }
  21. # 点赞+喜欢
  22. public function submit($uid, $id, $type)
  23. {
  24. $where['uid'] = $uid;
  25. $where['data_id'] = $id;
  26. $where['type'] = $type;
  27. $info = Dever::db('act/like')->one($where);
  28. if (!$info) {
  29. Dever::db('act/live')->insert($where);
  30. } else {
  31. if ($info['state'] == 1) {
  32. Dever::db('act/like')->update(array('where_id' => $info['id'], 'state' => 2));
  33. } else {
  34. Dever::db('act/like')->update(array('where_id' => $info['id'], 'state' => 1));
  35. }
  36. }
  37. # 更新点赞数
  38. $where = array();
  39. $where['data_id'] = $id;
  40. $where['type'] = $type;
  41. $total = Dever::db('act/like')->total($where);
  42. $table = Dever::config('base')->type_table[$type];
  43. Dever::db($table)->update(array('where_id' => $id, 'num_up' => $total));
  44. return true;
  45. }
  46. }