Data.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. namespace Push\Lib;
  3. use Dever;
  4. class Data
  5. {
  6. # 获取某个页面的数据
  7. public function getPage($page_id, $cdate = 'Y-m-d H:i')
  8. {
  9. $data = Dever::db('push/page')->find($page_id);
  10. if ($data) {
  11. $data['info'] = Dever::db('push/info')->select(array('page_id' => $page_id));
  12. if ($data['info']) {
  13. foreach ($data['info'] as $k => $v) {
  14. $where = array();
  15. $where['info_id'] = $v['id'];
  16. $where['limit'] = '0,' . $v['num'];
  17. $data['info'][$k]['data'] = Dever::db('push/data')->getAll($where);
  18. if ($data['info'][$k]['data']) {
  19. foreach ($data['info'][$k]['data'] as $k1 => $v1) {
  20. $data['info'][$k]['data'][$k1] = $this->getOne($v1, 2, $cdate);
  21. }
  22. }
  23. $data['info'][$k]['template'] = Dever::db('push/template')->find($v['template_id']);
  24. }
  25. }
  26. }
  27. return $data;
  28. }
  29. # 获取某个推送位的所有数据
  30. public function get($key, $name, $total = 10, $col = '1,2,3', $func = '-1', $page = false, $limit = false, $cdate = 'Y-m-d H:i')
  31. {
  32. $info = Dever::db('push/info')->one(array('key' => $key));
  33. if (!$info) {
  34. $insert['key'] = $key;
  35. $insert['name'] = $name;
  36. $insert['num'] = $total;
  37. $insert['col'] = $col;
  38. $insert['func'] = $func;
  39. $info['id'] = Dever::db('push/info')->insert($insert);
  40. $info['num'] = $insert['num'];
  41. }
  42. $data = array();
  43. if ($info) {
  44. if (!$info['num']) {
  45. $info['num'] = 20;
  46. }
  47. if ($limit > 0) {
  48. $info['num'] = $limit;
  49. }
  50. $where = array();
  51. $where['info_id'] = $info['id'];
  52. if ($page) {
  53. $where['page'] = array($info['num'], 'list');
  54. $data = Dever::db('push/data')->getAllPage($where);
  55. } else {
  56. $where['limit'] = '0,' . $info['num'];
  57. $data = Dever::db('push/data')->getAll($where);
  58. }
  59. if ($data) {
  60. foreach ($data as $k => $v) {
  61. $data[$k] = $this->getOne($v, 2, $cdate);
  62. }
  63. }
  64. }
  65. return $data;
  66. }
  67. # 获取某条推送位的数据
  68. public function getOne($info, $state = 2, $cdate = 'Y-m-d H:i')
  69. {
  70. $data = is_array($info) ? $info : Dever::db('push/data')->one($info);
  71. $source = array();
  72. $info = array();
  73. $col = array();
  74. if ($data['type'] > 0) {
  75. $func = Dever::db('push/func')->one($data['type']);
  76. if ($func) {
  77. if ($func['type'] == 1) {
  78. $method = $func['api'];
  79. $col = Dever::array_decode($func['col']);
  80. $source = Dever::load($method, $data['type_id']);
  81. } else {
  82. $data['type_id'] = $func['api'];
  83. }
  84. }
  85. }
  86. if ($state == 1) {
  87. $result = array();
  88. } else {
  89. $result = $data;
  90. $result['cdate_string'] = date($cdate, $result['cdate']);
  91. }
  92. $lang = Dever::getLang();
  93. if ($lang) {
  94. $key = $lang . '_col_';
  95. } else {
  96. $key = 'col_';
  97. }
  98. foreach ($data as $k => $v) {
  99. $s = strstr($k, $key);
  100. if ($lang && strstr($k, 'col_') && !$s) {
  101. $s = true;
  102. $key = 'col_';
  103. }
  104. if ($s) {
  105. $id = str_replace($key, '', $k);
  106. $col_info = Dever::db('push/col')->one($id);
  107. if (!$col_info) {
  108. continue;
  109. }
  110. if (!$v && $source && $col) {
  111. foreach ($col as $k1 => $v1) {
  112. if ($v1['col_id'] == $id && isset($source[$v1['name']]) && $source[$v1['name']]) {
  113. $v = $source[$v1['name']];
  114. }
  115. }
  116. }
  117. if ($state == 1) {
  118. if (strstr($v, 'jpg') || strstr($v, 'png') || strstr($v, 'gif')) {
  119. $v = '<img src="'.$v.'" width="150"/>';
  120. }
  121. if (!isset($result[$k])) {
  122. $result[$k] = array();
  123. }
  124. $result[$k][$col_info['name']] = $v;
  125. } else {
  126. $result[$col_info['key']] = $v;
  127. }
  128. }
  129. }
  130. return $result;
  131. }
  132. }