event_joinlist_export.inc.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <?php
  2. /**
  3. * [超级活动(xj_event.{modulename})] (C)2012-2099 Powered by 逍遥工作室.
  4. * Version: 1.0
  5. * Date: 2012-9-15 10:27
  6. */
  7. if (!defined('IN_DISCUZ')) {
  8. exit('Access Denied');
  9. }
  10. //调用核心类
  11. include 'source/plugin/xj_event/include/core.class.php';
  12. $eventcore = new xj_eventcore();
  13. $filename = date('Ymd', TIMESTAMP) . '.csv';
  14. header('Content-Encoding: none');
  15. header('Content-Type: application/octet-stream');
  16. header('Content-Disposition: attachment; filename=' . $filename);
  17. header('Pragma: no-cache');
  18. header('Expires: 0');
  19. //签到
  20. if (file_exists(DISCUZ_ROOT . './source/plugin/xj_event/module/signed/wsq_signed.php')) {
  21. $signed_enable = true;
  22. }
  23. include DISCUZ_ROOT . './source/plugin/xj_event/include/func.php';
  24. $tid = intval($_GET['tid']);
  25. //权限限制
  26. $thread = DB::fetch_first("SELECT authorid,userfield,setting FROM " . DB::table('forum_thread') . " A," . DB::table('xj_event') . " B WHERE A.tid='$tid' and A.tid = B.tid");
  27. $setting = unserialize($thread['setting']);
  28. if ($_G['groupid'] > 1 && $_G['uid'] != $thread['authorid']) {
  29. showmessage('quickclear_noperm');
  30. }
  31. //活动报名字段
  32. $selectuserfield = unserialize($thread['userfield']);
  33. $sysuserfield = unserialize($_G['setting']['activityfield']);
  34. //新的报名字段
  35. if($setting['myuserfield']){
  36. $myuserfield = $eventcore->GetUserField($setting['myuserfield']);
  37. }
  38. $query = DB::query("SELECT B.username,A.* FROM " . DB::table('xj_eventapply') . " A," . DB::table('common_member') . " B WHERE A.uid = B.uid and A.tid = '$tid' ORDER BY A.verify,A.dateline DESC,A.first DESC");
  39. require_once libfile('function/profile');
  40. loadcache('profilesetting');
  41. $i = 1;
  42. $detail = lang('plugin/xj_event', 'xuhao') . "," . lang('plugin/xj_event', 'yonghuming') . ",";
  43. if ($setting['session']) {
  44. $detail = $detail . lang('plugin/xj_event', 'huodongcc') . ",";
  45. }
  46. foreach ($selectuserfield as $val) {
  47. if ($sysuserfield[$val]) {
  48. $detail = $detail . $sysuserfield[$val] . ",";
  49. }
  50. }
  51. foreach($myuserfield as $val){
  52. $detail = $detail . $val['title'] . ",";
  53. }
  54. $detail = $detail . lang('plugin/xj_event', 'baomingrs') . ",";
  55. //多种费用报名内容
  56. if ($setting['cost']) {
  57. if ($setting['nodaibaoming']) {
  58. foreach ($setting['cost'] as $value) {
  59. $detail = $detail . $value['cost_name'] . ",";
  60. }
  61. } else {
  62. $detail .= lang('plugin/xj_event', 'leixin') . ",";
  63. }
  64. }
  65. $detail = $detail . 'message' . ",";
  66. if ($setting['eventpay']) {
  67. $detail .= lang('plugin/xj_event', 'zhifufy') . "," . lang('plugin/xj_event', 'zhifuleixing') . "," . lang('plugin/xj_event', 'zhifufy') . ",";
  68. }
  69. //验证码
  70. if ($setting['seccode']) {
  71. $detail .= lang('plugin/xj_event', 'yanzhenma') . ',' . lang('plugin/xj_event', 'yzmzt') . ',' . lang('plugin/xj_event', 'yanzsj') . ',';
  72. }
  73. $detail .= lang('plugin/xj_event', 'shenhe') . "," . lang('plugin/xj_event', 'baomingsj') . "," . lang('plugin/xj_event', 'qiandsj') . "\n";
  74. while ($value = DB::fetch($query)) {
  75. $value['No'] = $i;
  76. $value['dateline'] = date('Y-m-d H:i:s', $value['dateline']);
  77. $detail = $detail . $value['No'] . "," . ($value['first'] ? $value['username'] : '') . ",";
  78. if ($setting['session']) {
  79. $detail = $detail . $setting['session'][$value['session']] . ",";
  80. }
  81. $value['ufielddata'] = unserialize($value['ufielddata']);
  82. $data = '';
  83. foreach ($selectuserfield as $val) {
  84. if ($sysuserfield[$val]) {
  85. $data = profile_show($val, $value['ufielddata']);
  86. if ($_G['cache']['profilesetting'][$val]['formtype'] == 'file') {
  87. $data = '<a href="' . $data . '" target="_blank" onclick="zoom(this, this.href, 0, 0, 0); return false;">' . lang('forum/misc', 'activity_viewimg') . '</a>';
  88. }
  89. if ($val == 'birthday') {
  90. $data = $value['ufielddata'][$val];
  91. }
  92. if ($val == 'qq') {
  93. $data = $value['ufielddata'][$val];
  94. }
  95. $data = str_replace("\r", '', $data);
  96. $data = str_replace("\n", '', $data);
  97. $detail = $detail . "\t" . str_replace(',', ' ', $data) . ",";
  98. }
  99. }
  100. foreach($myuserfield as $val){
  101. $data = $value['ufielddata']['myfield'.$val['id']];
  102. $data = str_replace("\r", '', $data);
  103. $data = str_replace("\n", '', $data);
  104. $detail = $detail . "\t" . str_replace(',', ' ', $data) . ",";
  105. }
  106. /*
  107. $ufielddata = array();
  108. foreach($value['ufielddata'] as $key => $fieldid) {
  109. $data = profile_show($key, $value['ufielddata']);
  110. if($_G['cache']['profilesetting'][$key]['formtype'] == 'file') {
  111. $data = '<a href="'.$data.'" target="_blank" onclick="zoom(this, this.href, 0, 0, 0); return false;">'.lang('forum/misc', 'activity_viewimg').'</a>';
  112. }
  113. if($key=='birthday'){
  114. $data = $fieldid;
  115. }
  116. if($key=='qq'){
  117. $data = $fieldid;
  118. }
  119. $ufielddata[$key]['value'] = $data;
  120. $value[$key] = str_replace(',',' ',$data);
  121. $data = str_replace("\r",'',$data);
  122. $data = str_replace("\n",'',$data);
  123. $detail = $detail."\t".str_replace(',',' ',$data).",";
  124. }
  125. */
  126. //print_r($ufielddata);
  127. //$value['ufielddata'] = $ufielddata;
  128. $detail = $detail . $value['applynumber'] . ",";
  129. //多种费用报名内容
  130. foreach ($setting['cost'] as $costvalue) {
  131. $value['cost' . $costvalue['id']] = $value['ufielddata']['cost' . $costvalue['id']];
  132. }
  133. $value['costclass'] = $value['ufielddata']['costclass'];
  134. if ($setting['cost']) {
  135. if ($setting['nodaibaoming']) {
  136. foreach ($setting['cost'] as $cvalue) {
  137. $detail = $detail . $value['ufielddata']['cost' . $cvalue['id']] . ",";
  138. }
  139. } else {
  140. $detail .= $setting['cost'][$value['costclass']]['cost_name'] . ",";
  141. }
  142. }
  143. $detail = $detail . $value['bmmessage'] . ",";
  144. //支付情况
  145. if ($setting['eventpay']) {
  146. if ($value['pay_state'] == 1) {
  147. $detail .= lang('plugin/xj_event', 'yizhifu') . ",";
  148. } else {
  149. $detail .= lang('plugin/xj_event', 'weizhifu') . ",";
  150. }
  151. $paylog = DB::fetch_first("SELECT * FROM " . DB::table('xj_eventpay_log') . " WHERE applyid=" . $value['applyid'] . " ORDER BY create_time DESC");
  152. $detail .= $paylog['paytype'] . "," . $paylog['total_fee'] . ",";
  153. }
  154. //验证码
  155. if ($setting['seccode']) {
  156. $detail .= $value['seccode'] . ',';
  157. if ($value['secstate']) {
  158. $detail .= lang('plugin/xj_event', 'yiyanzhen') . ',';
  159. } else {
  160. $detail .= ',';
  161. }
  162. $detail .= dgmdate($value['sectime']) . ',';
  163. }
  164. if ($value['verify'] == 1) {
  165. $detail = $detail . lang('plugin/xj_event', 'yishenhe') . ",";
  166. } else {
  167. $detail = $detail . lang('plugin/xj_event', 'weishenhe') . ",";
  168. }
  169. $detail = $detail . $value['dateline'];
  170. //签到
  171. if ($signed_enable) {
  172. $signed = DB::fetch_first("SELECT * FROM " . DB::table('xj_event_signed') . " WHERE tid='$tid' AND uid=" . $value['uid']);
  173. if ($signed) {
  174. $value['signed_dateline'] = $signed['dateline'] ? dgmdate($signed['dateline']) : '';
  175. }
  176. $detail = $detail . "," . $value['signed_dateline'];
  177. }
  178. $detail = $detail . "\n";
  179. $i++;
  180. }
  181. if ($_G['charset'] != 'gbk') {
  182. $detail = diconv($detail, $_G['charset'], 'GBK');
  183. }
  184. echo $detail;
  185. exit();