PageRenderTime 26ms CodeModel.GetById 17ms RepoModel.GetById 0ms app.codeStats 1ms

/plugins/com_acymailing_starter_2.0.0_2011-07-06/back/views/subscriber/view.html.php

https://gitlab.com/endomorphosis/OLAAaction
PHP | 273 lines | 268 code | 1 blank | 4 comment | 47 complexity | 7a2a4d5141ebf2e78d8c43efe43b6e9d MD5 | raw file
  1. <?php
  2. /**
  3. * @copyright Copyright (C) 2009-2011 ACYBA SARL - All rights reserved.
  4. * @license http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
  5. */
  6. defined('_JEXEC') or die('Restricted access');
  7. ?>
  8. <?php
  9. class SubscriberViewSubscriber extends JView
  10. {
  11. var $searchFields = array('a.name','a.email','a.subid','a.userid','b.username');
  12. var $selectedFields = array('a.*','b.username');
  13. function display($tpl = null)
  14. {
  15. $function = $this->getLayout();
  16. if(method_exists($this,$function)) $this->$function();
  17. parent::display($tpl);
  18. }
  19. function listing(){
  20. $pageInfo = null;
  21. $app =& JFactory::getApplication();
  22. $config = acymailing_config();
  23. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName();
  24. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.subid','cmd' );
  25. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  26. $selectedList = $app->getUserStateFromRequest( $paramBase."filter_lists",'filter_lists',0,'int');
  27. $selectedStatus = $app->getUserStateFromRequest( $paramBase."filter_status",'filter_status',0,'int');
  28. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  29. $pageInfo->search = JString::strtolower( $pageInfo->search );
  30. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  31. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  32. $database =& JFactory::getDBO();
  33. $displayFields = array();
  34. $displayFields['name'] = null;
  35. $displayFields['name']->fieldname = 'JOOMEXT_NAME';
  36. $displayFields['email'] = null;
  37. $displayFields['email']->fieldname = 'JOOMEXT_EMAIL';
  38. $displayFields['html'] = null;
  39. $displayFields['html']->fieldname = 'RECEIVE_HTML';
  40. $filters = array();
  41. if(!empty($pageInfo->search)){
  42. foreach($displayFields as $fieldname => $onfield){
  43. if($fieldname == 'html' OR in_array('a.'.$fieldname,$this->searchFields)) continue;
  44. $this->searchFields[] = 'a.`'.$fieldname.'`';
  45. }
  46. $searchVal = '\'%'.$database->getEscaped($pageInfo->search,true).'%\'';
  47. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  48. }
  49. $leftJoinQuery = array();
  50. if(empty($selectedList) || ($selectedStatus == -2)){
  51. if(empty($selectedList) && $selectedStatus == -2) $selectedStatus = 0;
  52. $fromQuery = ' FROM '.acymailing_table('subscriber').' as a ';
  53. $countField = "a.subid";
  54. $leftJoinQuery[] = acymailing_table('users',false).' as b ON a.userid = b.id';
  55. if($selectedStatus == 1){
  56. $filters[] = 'a.accept > 0';
  57. }elseif($selectedStatus == -1){
  58. $filters[] = 'a.accept < 1';
  59. }elseif($selectedStatus == -2){
  60. $leftJoinQuery[] = acymailing_table('listsub').' as c on a.subid = c.subid AND listid = '.$selectedList;
  61. $filters[] = 'c.listid IS NULL';
  62. }elseif($selectedStatus == 2){
  63. $filters[] = 'a.confirmed < 1';
  64. }elseif($selectedStatus == 3){
  65. $filters[] = 'a.enabled > 0';
  66. }elseif($selectedStatus == -3){
  67. $filters[] = 'a.enabled < 1';
  68. }
  69. }else{
  70. $fromQuery = ' FROM '.acymailing_table('listsub').' as c';
  71. $countField = "c.subid";
  72. $leftJoinQuery[] = acymailing_table('subscriber').' as a ON a.subid = c.subid';
  73. $leftJoinQuery[] = acymailing_table('users',false).' as b ON a.userid = b.id';
  74. $filters[] = 'c.listid = '.intval($selectedList);
  75. if(!in_array($selectedStatus,array(-1,1,2))) $selectedStatus = 1;
  76. $filters[] = 'c.status = '.$selectedStatus;
  77. }
  78. $query = 'SELECT '.implode(',',$this->selectedFields).$fromQuery;
  79. if(!empty($leftJoinQuery)){
  80. $query .= ' LEFT JOIN '.implode(' LEFT JOIN ',$leftJoinQuery);
  81. }
  82. if(!empty($filters)){
  83. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  84. }
  85. if(!empty($pageInfo->filter->order->value)){
  86. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  87. }
  88. $database->setQuery($query,$pageInfo->limit->start,empty($pageInfo->limit->value) ? 500 : $pageInfo->limit->value);
  89. $rows = $database->loadObjectList('subid');
  90. $pageInfo->elements->page = count($rows);
  91. if($pageInfo->limit->value > $pageInfo->elements->page){
  92. $pageInfo->elements->total = $pageInfo->limit->start + $pageInfo->elements->page;
  93. }else{
  94. $queryCount = 'SELECT COUNT('.$countField.') '.$fromQuery;
  95. if(!empty($filters)){
  96. if(!empty($leftJoinQuery)) $queryCount .= ' LEFT JOIN '.implode(' LEFT JOIN ',$leftJoinQuery);
  97. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  98. }
  99. $database->setQuery($queryCount);
  100. $pageInfo->elements->total = $database->loadResult();
  101. }
  102. if(!empty($rows)){
  103. $database->setQuery('SELECT * FROM `#__acymailing_listsub` WHERE `subid` IN (\''.implode('\',\'',array_keys($rows)).'\')');
  104. $subscriptions = $database->loadObjectList();
  105. if(!empty($subscriptions)){
  106. foreach($subscriptions as $onesub){
  107. $sublistid = $onesub->listid;
  108. $rows[$onesub->subid]->subscription->$sublistid = $onesub;
  109. }
  110. }
  111. }
  112. if(!empty($pageInfo->search)){
  113. $rows = acymailing_search($pageInfo->search,$rows);
  114. }
  115. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  116. jimport('joomla.html.pagination');
  117. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  118. $filters = null;
  119. if(empty($selectedList)){
  120. $statusType = acymailing_get('type.statusfilter');
  121. }else{
  122. $statusType = acymailing_get('type.statusfilterlist');
  123. }
  124. $listsType = acymailing_get('type.lists');
  125. $filters->status = $statusType->display('filter_status',$selectedStatus);
  126. $filters->lists = $listsType->display('filter_lists',$selectedList);
  127. acymailing_setTitle(JText::_('USERS'),'acyusers','subscriber');
  128. $bar = & JToolBar::getInstance('toolbar');
  129. if(acymailing_isAllowed($config->get('acl_lists_filter','all'))){
  130. $bar->appendButton( 'Acyactions');
  131. JToolBarHelper::divider();
  132. }
  133. if(acymailing_isAllowed($config->get('acl_subscriber_import','all'))) $bar->appendButton( 'Link', 'import', JText::_('IMPORT'), acymailing_completeLink('data&task=import') );
  134. if(acymailing_isAllowed($config->get('acl_subscriber_export','all'))) JToolBarHelper::custom('export', 'acyexport', '',JText::_('ACY_EXPORT'), false);
  135. JToolBarHelper::divider();
  136. if(acymailing_isAllowed($config->get('acl_subscriber_manage','all'))) JToolBarHelper::addNew();
  137. if(acymailing_isAllowed($config->get('acl_subscriber_manage','all'))) JToolBarHelper::editList();
  138. if(acymailing_isAllowed($config->get('acl_subscriber_delete','all'))) JToolBarHelper::deleteList(JText::_('ACY_VALIDDELETEITEMS',true));
  139. JToolBarHelper::divider();
  140. $bar->appendButton( 'Pophelp','subscriber-listing');
  141. if(acymailing_isAllowed($config->get('acl_cpanel_manage','all'))) $bar->appendButton( 'Link', 'acymailing', JText::_('ACY_CPANEL'), acymailing_completeLink('dashboard') );
  142. $lists = $listsType->getData();
  143. $this->assignRef('lists',$lists);
  144. $toggleClass = acymailing_get('helper.toggle');
  145. $this->assignRef('toggleClass',$toggleClass);
  146. $this->assignRef('rows',$rows);
  147. $this->assignRef('filters',$filters);
  148. $this->assignRef('pageInfo',$pageInfo);
  149. $this->assignRef('pagination',$pagination);
  150. $config = acymailing_config();
  151. $this->assignRef('config',$config);
  152. $this->assignRef('displayFields',$displayFields);
  153. $customFields = acymailing_get('class.fields');
  154. $this->assignRef('customFields',$customFields);
  155. }
  156. function choose(){
  157. $pageInfo = null;
  158. $app =& JFactory::getApplication();
  159. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName().'_'.$this->getLayout();
  160. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.name','cmd' );
  161. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'asc', 'word' );
  162. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  163. $pageInfo->search = JString::strtolower( $pageInfo->search );
  164. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  165. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  166. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  167. $db =& JFactory::getDBO();
  168. $filters = array();
  169. if(!empty($pageInfo->search)){
  170. $searchVal = '\'%'.$db->getEscaped($pageInfo->search,true).'%\'';
  171. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  172. }
  173. if(JRequest::getString('onlyreg')){
  174. $filters[] = 'a.userid > 0';
  175. }
  176. $query = 'SELECT '.implode(',',$this->selectedFields).' FROM #__acymailing_subscriber as a';
  177. $query .= ' LEFT JOIN #__users as b on a.userid = b.id';
  178. if(!empty($filters)){
  179. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  180. }
  181. if(!empty($pageInfo->filter->order->value)){
  182. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  183. }
  184. $db->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  185. $rows = $db->loadObjectList();
  186. $queryWhere = 'SELECT COUNT(a.subid) FROM #__acymailing_subscriber as a';
  187. if(!empty($filters)){
  188. $queryWhere .= ' LEFT JOIN #__users as b on a.userid = b.id';
  189. $queryWhere .= ' WHERE ('.implode(') AND (',$filters).')';
  190. }
  191. $db->setQuery($queryWhere);
  192. $pageInfo->elements->total = $db->loadResult();
  193. if(!empty($pageInfo->search)){
  194. $rows = acymailing_search($pageInfo->search,$rows);
  195. }
  196. $pageInfo->elements->page = count($rows);
  197. jimport('joomla.html.pagination');
  198. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  199. $this->assignRef('rows',$rows);
  200. $this->assignRef('pageInfo',$pageInfo);
  201. $this->assignRef('pagination',$pagination);
  202. }
  203. function form(){
  204. $subid = acymailing_getCID('subid');
  205. $db =& JFactory::getDBO();
  206. if(!empty($subid)){
  207. $subscriberClass = acymailing_get('class.subscriber');
  208. $subscriber = $subscriberClass->getFull($subid);
  209. $subscription = $subscriberClass->getSubscription($subid);
  210. }else{
  211. $listType = acymailing_get('class.list');
  212. $subscription = $listType->getLists();
  213. $subscriber = null;
  214. $subscriber->created = time();
  215. $subscriber->html = 1;
  216. $subscriber->confirmed = 1;
  217. $subscriber->blocked = 0;
  218. $subscriber->accept = 1;
  219. $subscriber->enabled = 1;
  220. $iphelper = acymailing_get('helper.user');
  221. $subscriber->ip = $iphelper->getIP();
  222. }
  223. acymailing_setTitle(JText::_('ACY_USER'),'acyusers','subscriber&task=edit&subid='.$subid);
  224. $bar = & JToolBar::getInstance('toolbar');
  225. if(!empty($subid)){
  226. $query = 'SELECT a.`mailid`, a.`html`, a.`sent`, a.`senddate`,a.`open`, a.`opendate`, a.`bounce`, a.`fail`,b.`subject`,b.`alias`';
  227. $query .= ' FROM `#__acymailing_userstats` as a';
  228. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  229. $query .= ' WHERE a.subid = '.intval($subid).' ORDER BY a.senddate DESC LIMIT 30';
  230. $db->setQuery($query);
  231. $open = $db->loadObjectList();
  232. $this->assignRef('open',$open);
  233. $query = 'SELECT a.*,b.`subject`,b.`alias`';
  234. $query .= ' FROM `#__acymailing_queue` as a';
  235. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  236. $query .= ' WHERE a.subid = '.intval($subid).' ORDER BY a.senddate ASC LIMIT 60';
  237. $db->setQuery($query);
  238. $queue = $db->loadObjectList();
  239. $this->assignRef('queue',$queue);
  240. $query = 'SELECT * FROM #__acymailing_history WHERE subid = '.intval($subid).' ORDER BY `date` DESC LIMIT 30';
  241. $db->setQuery($query);
  242. $history = $db->loadObjectList();
  243. $this->assignRef('history',$history);
  244. }
  245. if(!empty($subscriber->userid)){
  246. if(file_exists(ACYMAILING_ROOT.'components'.DS.'com_comprofiler'.DS.'comprofiler.php')){
  247. $editLink = 'index.php?option=com_comprofiler&task=edit&cid[]=';
  248. }elseif(version_compare(JVERSION,'1.6.0','<')){
  249. $editLink = 'index.php?option=com_users&task=edit&cid[]=';
  250. }else{
  251. $editLink = 'index.php?option=com_users&task=user.edit&id=';
  252. }
  253. $bar->appendButton( 'Link', 'edit', JText::_('EDIT_JOOMLA_USER'), $editLink.$subscriber->userid );
  254. JToolBarHelper::spacer();
  255. }
  256. JToolBarHelper::save();
  257. JToolBarHelper::apply();
  258. JToolBarHelper::cancel();
  259. JToolBarHelper::divider();
  260. $bar->appendButton( 'Pophelp','subscriber-form');
  261. $filters = null;
  262. $quickstatusType = acymailing_get('type.statusquick');
  263. $filters->statusquick = $quickstatusType->display('statusquick');
  264. $this->assignRef('subscriber',$subscriber);
  265. $toggleClass = acymailing_get('helper.toggle');
  266. $this->assignRef('toggleClass',$toggleClass);
  267. $this->assignRef('subscription',$subscription);
  268. $this->assignRef('filters',$filters);
  269. $statusType = acymailing_get('type.status');
  270. $this->assignRef('statusType',$statusType);
  271. }
  272. }