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

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

https://gitlab.com/endomorphosis/OLAAaction
PHP | 101 lines | 97 code | 0 blank | 4 comment | 13 complexity | 42d65c2be4d7d39a5752bb5aac7c0816 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 QueueViewQueue extends JView
  10. {
  11. var $searchFields = array('b.name','b.email','c.subject','a.mailid','a.subid');
  12. var $selectFields = array('b.name','b.email','c.subject','c.type','c.published','a.mailid','a.subid','a.senddate','a.priority','a.try');
  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. $app =& JFactory::getApplication();
  21. $pageInfo = null;
  22. $config = acymailing_config();
  23. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName();
  24. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.senddate','cmd' );
  25. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'asc', 'word' );
  26. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  27. $pageInfo->search = JString::strtolower( $pageInfo->search );
  28. $selectedMail = $app->getUserStateFromRequest( $paramBase."filter_mail",'filter_mail',0,'int');
  29. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  30. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  31. $database =& JFactory::getDBO();
  32. $filters = array();
  33. if(!empty($pageInfo->search)){
  34. $searchVal = '\'%'.$database->getEscaped($pageInfo->search,true).'%\'';
  35. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  36. }
  37. if(!empty($selectedMail)) $filters[] = 'a.mailid = '.intval($selectedMail);
  38. $query = 'SELECT '.implode(' , ',$this->selectFields);
  39. $query .= ' FROM '.acymailing_table('queue').' as a';
  40. $query .= ' LEFT JOIN '.acymailing_table('subscriber').' as b on a.subid = b.subid';
  41. $query .= ' LEFT JOIN '.acymailing_table('mail').' as c on a.mailid = c.mailid';
  42. if(!empty($filters)) $query .= ' WHERE ('.implode(') AND (',$filters).')';
  43. if(!empty($pageInfo->filter->order->value)){
  44. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir.', a.`subid` ASC';
  45. }
  46. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  47. $database->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  48. $rows = $database->loadObjectList();
  49. $queryCount = 'SELECT COUNT(a.mailid) FROM '.acymailing_table('queue').' as a';
  50. if(!empty($filters)){
  51. $queryCount .= ' LEFT JOIN '.acymailing_table('subscriber').' as b on a.subid = b.subid';
  52. $queryCount .= ' LEFT JOIN '.acymailing_table('mail').' as c on a.mailid = c.mailid';
  53. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  54. }
  55. $database->setQuery($queryCount);
  56. $pageInfo->elements->total = $database->loadResult();
  57. if(!empty($pageInfo->search)){
  58. $rows = acymailing_search($pageInfo->search,$rows);
  59. }
  60. $pageInfo->elements->page = count($rows);
  61. jimport('joomla.html.pagination');
  62. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  63. $mailqueuetype = acymailing_get('type.queuemail');
  64. $filtersType = null;
  65. $filtersType->mail = $mailqueuetype->display('filter_mail',$selectedMail);
  66. acymailing_setTitle(JText::_('QUEUE'),'process','queue');
  67. $bar = & JToolBar::getInstance('toolbar');
  68. if(acymailing_isAllowed($config->get('acl_queue_process','all'))) $bar->appendButton( 'Popup', 'process', JText::_('PROCESS'), "index.php?option=com_acymailing&ctrl=queue&task=process&tmpl=component&mailid=".$selectedMail);
  69. if(!empty($pageInfo->elements->total) AND acymailing_isAllowed($config->get('acl_queue_delete','all'))){
  70. JToolBarHelper::spacer();
  71. JToolBarHelper::spacer();
  72. $bar->appendButton( 'Confirm', JText::sprintf('CONFIRM_DELETE_QUEUE',$pageInfo->elements->total), 'delete', JText::_('ACY_DELETE'), 'remove', false, false );
  73. }
  74. JToolBarHelper::divider();
  75. $bar->appendButton( 'Pophelp','queue-listing');
  76. if(acymailing_isAllowed($config->get('acl_cpanel_manage','all'))) $bar->appendButton( 'Link', 'acymailing', JText::_('ACY_CPANEL'), acymailing_completeLink('dashboard') );
  77. $toggleClass = acymailing_get('helper.toggle');
  78. $this->assignRef('toggleClass',$toggleClass);
  79. $this->assignRef('filters',$filtersType);
  80. $this->assignRef('rows',$rows);
  81. $this->assignRef('pageInfo',$pageInfo);
  82. $this->assignRef('pagination',$pagination);
  83. }
  84. function process(){
  85. $mailid = acymailing_getCID('mailid');
  86. $queueClass = acymailing_get('class.queue');
  87. $queueStatus = $queueClass->queueStatus($mailid);
  88. $nextqueue = $queueClass->queueStatus($mailid,true);
  89. if(acymailing_level(1)){
  90. $scheduleClass = acymailing_get('helper.schedule');
  91. $scheduleNewsletter = $scheduleClass->getScheduled();
  92. $this->assignRef('schedNews',$scheduleNewsletter);
  93. }
  94. if(empty($queueStatus) AND empty($scheduleNewsletter)) acymailing_display(JText::_('NO_PROCESS'),'info');
  95. $infos = null;
  96. $infos->mailid = $mailid;
  97. $this->assignRef('queue',$queueStatus);
  98. $this->assignRef('nextqueue',$nextqueue);
  99. $this->assignRef('infos',$infos);
  100. }
  101. }