PageRenderTime 25ms CodeModel.GetById 17ms RepoModel.GetById 0ms app.codeStats 0ms

/administrator/components/com_acymailing/views/stats/view.html.php

https://gitlab.com/endomorphosis/OLAAaction
PHP | 217 lines | 213 code | 0 blank | 4 comment | 34 complexity | 08d8957f911001d36fc8ca73ed3aaa0e 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 StatsViewStats extends JView
  10. {
  11. var $searchFields = array('b.subject','a.mailid');
  12. var $selectFields = array('b.subject','b.type','a.*');
  13. var $searchHistory = array('b.subject','c.email','c.name');
  14. var $historyFields = array('a.*','b.subject','c.email','c.name');
  15. var $detailSearchFields = array('b.subject','a.mailid','c.name','c.email','a.subid');
  16. var $detailSelectFields = array('b.subject','c.name','c.email','b.type','a.*');
  17. function display($tpl = null)
  18. {
  19. $function = $this->getLayout();
  20. if(method_exists($this,$function)) $this->$function();
  21. parent::display($tpl);
  22. }
  23. function forward(){
  24. $this->unsubscribed();
  25. $this->setLayout('unsubscribed');
  26. }
  27. function unsubscribed(){
  28. $app =& JFactory::getApplication();
  29. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName().$this->getLayout();
  30. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.date','cmd' );
  31. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  32. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  33. $pageInfo->search = JString::strtolower( $pageInfo->search );
  34. $selectedMail = $app->getUserStateFromRequest( $paramBase."filter_mail",'filter_mail',0,'int');
  35. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  36. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  37. $db =& JFactory::getDBO();
  38. $filters = array();
  39. $filters[] = "a.action = ".$db->Quote($this->getLayout());
  40. if(!empty($pageInfo->search)){
  41. $searchVal = '\'%'.$db->getEscaped($pageInfo->search).'%\'';
  42. $filters[] = implode(" LIKE $searchVal OR ",$this->searchHistory)." LIKE $searchVal";
  43. }
  44. if(!empty($selectedMail)){
  45. $filters[] = 'a.mailid = '.$selectedMail;
  46. }
  47. $query = 'SELECT '.implode(' , ',$this->historyFields).' FROM '.acymailing_table('history').' as a';
  48. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  49. $query .= ' LEFT JOIN '.acymailing_table('subscriber').' as c on a.subid = c.subid';
  50. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  51. if(!empty($pageInfo->filter->order->value)) $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  52. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  53. $db->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  54. $rows = $db->loadObjectList();
  55. $queryCount = 'SELECT COUNT(*) FROM #__acymailing_history as a';
  56. if(!empty($pageInfo->search)){
  57. $queryCount .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  58. $queryCount .= ' LEFT JOIN '.acymailing_table('subscriber').' as c on a.subid = c.subid';
  59. }
  60. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  61. $db->setQuery($queryCount);
  62. $pageInfo->elements->total = $db->loadResult();
  63. if(!empty($pageInfo->search)){
  64. $rows = acymailing_search($pageInfo->search,$rows);
  65. }
  66. $pageInfo->elements->page = count($rows);
  67. jimport('joomla.html.pagination');
  68. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  69. $query = 'SELECT DISTINCT b.subject, a.mailid FROM '.acymailing_table('history').' as a';
  70. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid WHERE a.action = '.$db->Quote($this->getLayout()).' ORDER BY a.mailid DESC';
  71. $db->setQuery($query);
  72. $emails = $db->loadObjectList();
  73. $newsletters = array();
  74. $newsletters[] = JHTML::_('select.option', '0', JText::_('ALL_EMAILS') );
  75. foreach($emails as $oneMail){
  76. $newsletters[] = JHTML::_('select.option', $oneMail->mailid, $oneMail->subject );
  77. }
  78. $filterMail = JHTML::_('select.genericlist', $newsletters,'filter_mail', 'class="inputbox" size="1" onchange="document.adminForm.submit( );"', 'value', 'text', (int) $selectedMail );
  79. $this->assignRef('filterMail',$filterMail);
  80. $this->assignRef('rows',$rows);
  81. $this->assignRef('pageInfo',$pageInfo);
  82. $this->assignRef('pagination',$pagination);
  83. }
  84. function detaillisting(){
  85. $app =& JFactory::getApplication();
  86. $doc =& JFactory::getDocument();
  87. $doc->addStyleSheet( ACYMAILING_CSS.'frontendedition.css' );
  88. $pageInfo = null;
  89. $config = acymailing_config();
  90. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName().$this->getLayout();
  91. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.senddate','cmd' );
  92. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  93. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  94. $pageInfo->search = JString::strtolower( $pageInfo->search );
  95. $selectedMail = $app->getUserStateFromRequest( $paramBase."filter_mail",'filter_mail',0,'int');
  96. $selectedStatus = $app->getUserStateFromRequest( $paramBase."filter_status",'filter_status',0,'string');
  97. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  98. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  99. $database =& JFactory::getDBO();
  100. $filters = array();
  101. if(!empty($pageInfo->search)){
  102. $searchVal = '\'%'.$database->getEscaped($pageInfo->search).'%\'';
  103. $filters[] = implode(" LIKE $searchVal OR ",$this->detailSearchFields)." LIKE $searchVal";
  104. }
  105. if(!empty($selectedMail)) $filters[] = 'a.mailid = '.$selectedMail;
  106. if(!empty($selectedStatus)){
  107. if($selectedStatus == 'bounce') $filters[] = 'a.bounce > 0';
  108. elseif($selectedStatus == 'open') $filters[] = 'a.open > 0';
  109. elseif($selectedStatus == 'notopen') $filters[] = 'a.open < 1';
  110. elseif($selectedStatus == 'failed') $filters[] = 'a.fail > 0';
  111. }
  112. $query = 'SELECT '.implode(' , ',$this->detailSelectFields);
  113. $query .= ' FROM '.acymailing_table('userstats').' as a';
  114. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  115. $query .= ' LEFT JOIN '.acymailing_table('subscriber').' as c on a.subid = c.subid';
  116. if(!empty($filters)) $query .= ' WHERE ('.implode(') AND (',$filters).')';
  117. if(!empty($pageInfo->filter->order->value)) $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  118. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  119. $database->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  120. $rows = $database->loadObjectList();
  121. $queryCount = 'SELECT COUNT(a.subid) FROM #__acymailing_userstats as a';
  122. if(!empty($pageInfo->search)){
  123. $queryCount .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  124. $queryCount .= ' LEFT JOIN '.acymailing_table('subscriber').' as c on a.subid = c.subid';
  125. }
  126. if(!empty($filters)) $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  127. $database->setQuery($queryCount);
  128. $pageInfo->elements->total = $database->loadResult();
  129. if(!empty($pageInfo->search)){
  130. $rows = acymailing_search($pageInfo->search,$rows);
  131. }
  132. $pageInfo->elements->page = count($rows);
  133. jimport('joomla.html.pagination');
  134. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  135. $toggleClass = acymailing_get('helper.toggle');
  136. $maildetailstatstype = acymailing_get('type.detailstatsmail');
  137. $deliverstatus = acymailing_get('type.deliverstatus');
  138. $filtersType = null;
  139. if(JRequest::getString('tmpl') == 'component'){
  140. $filtersType->mail = '<input type="hidden" value="'.$selectedMail.'" name="filter_mail" />';
  141. $mailClass= acymailing_get('class.mail');
  142. $this->assignRef('mailing',$mailClass->get($selectedMail));
  143. }else{
  144. $filtersType->mail = $maildetailstatstype->display('filter_mail',$selectedMail);
  145. }
  146. $filtersType->status = $deliverstatus->display('filter_status',$selectedStatus);
  147. if($app->isAdmin()){
  148. acymailing_setTitle(JText::_('DETAILED_STATISTICS'),'stats','stats&task=detaillisting');
  149. $bar = & JToolBar::getInstance('toolbar');
  150. $bar->appendButton( 'Link', 'back', JText::_('GLOBAL_STATISTICS'), acymailing_completeLink('stats') );
  151. if(acymailing_isAllowed($config->get('acl_subscriber_export','all'))){
  152. JToolBarHelper::spacer();
  153. JToolBarHelper::custom('export', 'acyexport', '',JText::_('EXPORT'), false);
  154. }
  155. JToolBarHelper::divider();
  156. $bar->appendButton( 'Pophelp','stats-detaillisting');
  157. }
  158. $this->assignRef('filters',$filtersType);
  159. $this->assignRef('toggleClass',$toggleClass);
  160. $this->assignRef('rows',$rows);
  161. $this->assignRef('pageInfo',$pageInfo);
  162. $this->assignRef('pagination',$pagination);
  163. }
  164. function listing(){
  165. $app =& JFactory::getApplication();
  166. $pageInfo = null;
  167. $config = acymailing_config();
  168. JHTML::_('behavior.modal','a.modal');
  169. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName().$this->getLayout();
  170. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.senddate','cmd' );
  171. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  172. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  173. $pageInfo->search = JString::strtolower( $pageInfo->search );
  174. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  175. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  176. $database =& JFactory::getDBO();
  177. $filters = array();
  178. if(!empty($pageInfo->search)){
  179. $searchVal = '\'%'.$database->getEscaped($pageInfo->search,true).'%\'';
  180. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  181. }
  182. $query = 'SELECT '.implode(' , ',$this->selectFields);
  183. $query .= ' FROM '.acymailing_table('stats').' as a';
  184. $query .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  185. if(!empty($filters)) $query .= ' WHERE ('.implode(') AND (',$filters).')';
  186. if(!empty($pageInfo->filter->order->value)){
  187. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  188. }
  189. $database->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  190. $rows = $database->loadObjectList();
  191. $queryCount = 'SELECT COUNT(a.mailid) FROM '.acymailing_table('stats').' as a';
  192. if(!empty($pageInfo->search)){
  193. $queryCount .= ' LEFT JOIN '.acymailing_table('mail').' as b on a.mailid = b.mailid';
  194. }
  195. if(!empty($filters)) $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  196. $database->setQuery($queryCount);
  197. $pageInfo->elements->total = $database->loadResult();
  198. if(!empty($pageInfo->search)){
  199. $rows = acymailing_search($pageInfo->search,$rows);
  200. }
  201. $pageInfo->elements->page = count($rows);
  202. jimport('joomla.html.pagination');
  203. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  204. acymailing_setTitle(JText::_('GLOBAL_STATISTICS'),'stats','stats');
  205. $bar = & JToolBar::getInstance('toolbar');
  206. if(acymailing_level(1)) $bar->appendButton( 'Link', 'stats', JText::_('CHARTS'), acymailing_completeLink('diagram') );
  207. JToolBarHelper::spacer();
  208. JToolBarHelper::spacer();
  209. if(acymailing_isAllowed($config->get('acl_statistics_delete','all'))) JToolBarHelper::deleteList(JText::_('ACY_VALIDDELETEITEMS'));
  210. JToolBarHelper::divider();
  211. $bar->appendButton( 'Pophelp','stats-listing');
  212. if(acymailing_isAllowed($config->get('acl_cpanel_manage','all'))) $bar->appendButton( 'Link', 'acymailing', JText::_('ACY_CPANEL'), acymailing_completeLink('dashboard') );
  213. $this->assignRef('rows',$rows);
  214. $this->assignRef('pageInfo',$pageInfo);
  215. $this->assignRef('pagination',$pagination);
  216. }
  217. }