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

/master/administrator/components/com_acymailing/views/subscriber/view.html.php

https://github.com/sherdog/GitWitty
PHP | 291 lines | 287 code | 0 blank | 4 comment | 47 complexity | ca41de4dd36a26ef5a44f5f59b88557d MD5 | raw file
  1. <?php
  2. /**
  3. * @copyright Copyright (C) 2009-2011 ACYBA SARL - All rights reserved.
  4. * @license http://www.acyba.com/commercial_license.php
  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. $doc =& JFactory::getDocument();
  23. JHTML::_('behavior.modal','a.modal');
  24. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName();
  25. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.subid','cmd' );
  26. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  27. $selectedList = $app->getUserStateFromRequest( $paramBase."filter_lists",'filter_lists',0,'int');
  28. $selectedStatus = $app->getUserStateFromRequest( $paramBase."filter_status",'filter_status',0,'int');
  29. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  30. $pageInfo->search = JString::strtolower( $pageInfo->search );
  31. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  32. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  33. $database =& JFactory::getDBO();
  34. $displayFields = array();
  35. $displayFields['name'] = null;
  36. $displayFields['name']->fieldname = 'JOOMEXT_NAME';
  37. $displayFields['email'] = null;
  38. $displayFields['email']->fieldname = 'JOOMEXT_EMAIL';
  39. $displayFields['html'] = null;
  40. $displayFields['html']->fieldname = 'RECEIVE_HTML';
  41. if(acymailing::level(3)){
  42. $database->setQuery('SELECT `fieldname`,`namekey` FROM `#__acymailing_fields` WHERE `listing` = 1 ORDER BY `ordering` ASC');
  43. $displayFields = $database->loadObjectList('namekey');
  44. if(isset($displayFields['html'])){
  45. $displayFields['html']->fieldname = 'RECEIVE_HTML';
  46. }
  47. }
  48. $filters = array();
  49. if(!empty($pageInfo->search)){
  50. foreach($displayFields as $fieldname => $onfield){
  51. if($fieldname == 'html') continue;
  52. $this->searchFields[] = 'a.`'.$fieldname.'`';
  53. }
  54. $searchVal = '\'%'.$database->getEscaped($pageInfo->search,true).'%\'';
  55. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  56. }
  57. $leftJoinQuery = array();
  58. if(empty($selectedList) || ($selectedStatus == -2)){
  59. if(empty($selectedList) && $selectedStatus == -2) $selectedStatus = 0;
  60. $fromQuery = ' FROM '.acymailing::table('subscriber').' as a ';
  61. $countField = "a.subid";
  62. $leftJoinQuery[] = acymailing::table('users',false).' as b ON a.userid = b.id';
  63. if($selectedStatus == 1){
  64. $filters[] = 'a.accept > 0';
  65. }elseif($selectedStatus == -1){
  66. $filters[] = 'a.accept < 1';
  67. }elseif($selectedStatus == -2){
  68. $leftJoinQuery[] = acymailing::table('listsub').' as c on a.subid = c.subid AND listid = '.$selectedList;
  69. $filters[] = 'c.listid IS NULL';
  70. }elseif($selectedStatus == 2){
  71. $filters[] = 'a.confirmed < 1';
  72. }elseif($selectedStatus == 3){
  73. $filters[] = 'a.enabled > 0';
  74. }elseif($selectedStatus == -3){
  75. $filters[] = 'a.enabled < 1';
  76. }
  77. }else{
  78. $fromQuery = ' FROM '.acymailing::table('listsub').' as c';
  79. $countField = "c.subid";
  80. $leftJoinQuery[] = acymailing::table('subscriber').' as a ON a.subid = c.subid';
  81. $leftJoinQuery[] = acymailing::table('users',false).' as b ON a.userid = b.id';
  82. $filters[] = 'c.listid = '.intval($selectedList);
  83. if(!in_array($selectedStatus,array(-1,1,2))) $selectedStatus = 1;
  84. $filters[] = 'c.status = '.$selectedStatus;
  85. }
  86. $query = 'SELECT '.implode(',',$this->selectedFields).$fromQuery;
  87. if(!empty($leftJoinQuery)){
  88. $query .= ' LEFT JOIN '.implode(' LEFT JOIN ',$leftJoinQuery);
  89. }
  90. if(!empty($filters)){
  91. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  92. }
  93. if(!empty($pageInfo->filter->order->value)){
  94. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  95. }
  96. $database->setQuery($query,$pageInfo->limit->start,empty($pageInfo->limit->value) ? 500 : $pageInfo->limit->value);
  97. $rows = $database->loadObjectList('subid');
  98. $pageInfo->elements->page = count($rows);
  99. if($pageInfo->limit->value > $pageInfo->elements->page){
  100. $pageInfo->elements->total = $pageInfo->limit->start + $pageInfo->elements->page;
  101. }else{
  102. $queryCount = 'SELECT COUNT('.$countField.') '.$fromQuery;
  103. if(!empty($filters)){
  104. if(!empty($leftJoinQuery)) $queryCount .= ' LEFT JOIN '.implode(' LEFT JOIN ',$leftJoinQuery);
  105. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  106. }
  107. $database->setQuery($queryCount);
  108. $pageInfo->elements->total = $database->loadResult();
  109. }
  110. if(!empty($rows)){
  111. $database->setQuery('SELECT * FROM `#__acymailing_listsub` WHERE `subid` IN (\''.implode('\',\'',array_keys($rows)).'\')');
  112. $subscriptions = $database->loadObjectList();
  113. if(!empty($subscriptions)){
  114. foreach($subscriptions as $onesub){
  115. $sublistid = $onesub->listid;
  116. $rows[$onesub->subid]->subscription->$sublistid = $onesub;
  117. }
  118. }
  119. }
  120. if(!empty($pageInfo->search)){
  121. $rows = acymailing::search($pageInfo->search,$rows);
  122. }
  123. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  124. jimport('joomla.html.pagination');
  125. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  126. $filters = null;
  127. if(empty($selectedList)){
  128. $statusType = acymailing::get('type.statusfilter');
  129. }else{
  130. $statusType = acymailing::get('type.statusfilterlist');
  131. }
  132. $listsType = acymailing::get('type.lists');
  133. $filters->status = $statusType->display('filter_status',$selectedStatus);
  134. $filters->lists = $listsType->display('filter_lists',$selectedList);
  135. $js = "function massactions(){
  136. if(window.document.adminForm.boxchecked.value < 1){
  137. window.document.getElementById('massaction').style.display = 'none';
  138. return;
  139. }
  140. i = 0;
  141. mylink = 'index.php?option=com_acymailing&ctrl=filter&tmpl=component&subid=';
  142. while(window.document.getElementById('cb'+i)){
  143. if(window.document.getElementById('cb'+i).checked) mylink += window.document.getElementById('cb'+i).value+',';
  144. i++;
  145. }
  146. window.document.getElementById('masslink').href= mylink;
  147. window.document.getElementById('massaction').style.display = '';
  148. }";
  149. $doc->addScriptDeclaration( $js );
  150. acymailing::setTitle(JText::_('USERS'),'user','subscriber');
  151. $bar = & JToolBar::getInstance('toolbar');
  152. $bar->appendButton( 'Link', 'import', JText::_('IMPORT'), acymailing::completeLink('data&task=import') );
  153. JToolBarHelper::custom('export', 'acyexport', '',JText::_('ACY_EXPORT'), false);
  154. JToolBarHelper::divider();
  155. JToolBarHelper::addNew();
  156. JToolBarHelper::editList();
  157. JToolBarHelper::deleteList(JText::_('ACY_VALIDDELETEITEMS',true));
  158. JToolBarHelper::divider();
  159. $bar->appendButton( 'Pophelp','subscriber-listing');
  160. $bar->appendButton( 'Link', 'acymailing', JText::_('JOOMEXT_CPANEL'), acymailing::completeLink('dashboard') );
  161. $this->assignRef('lists',$listsType->getData());
  162. $this->assignRef('toggleClass',acymailing::get('helper.toggle'));
  163. $this->assignRef('rows',$rows);
  164. $this->assignRef('filters',$filters);
  165. $this->assignRef('pageInfo',$pageInfo);
  166. $this->assignRef('pagination',$pagination);
  167. $this->assignRef('config',acymailing::config());
  168. $this->assignRef('displayFields',$displayFields);
  169. $this->assignRef('customFields',acymailing::get('class.fields'));
  170. }
  171. function choose(){
  172. $pageInfo = null;
  173. $app =& JFactory::getApplication();
  174. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName().'_'.$this->getLayout();
  175. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.name','cmd' );
  176. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'asc', 'word' );
  177. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  178. $pageInfo->search = JString::strtolower( $pageInfo->search );
  179. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  180. $pageInfo->limit->start = $app->getUserStateFromRequest( $paramBase.'.limitstart', 'limitstart', 0, 'int' );
  181. if(empty($pageInfo->limit->value)) $pageInfo->limit->value = 100;
  182. $db =& JFactory::getDBO();
  183. $filters = array();
  184. if(!empty($pageInfo->search)){
  185. $searchVal = '\'%'.$db->getEscaped($pageInfo->search,true).'%\'';
  186. $filters[] = implode(" LIKE $searchVal OR ",$this->searchFields)." LIKE $searchVal";
  187. }
  188. if(JRequest::getString('onlyreg')){
  189. $filters[] = 'a.userid > 0';
  190. }
  191. $query = 'SELECT '.implode(',',$this->selectedFields).' FROM #__acymailing_subscriber as a';
  192. $query .= ' LEFT JOIN #__users as b on a.userid = b.id';
  193. if(!empty($filters)){
  194. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  195. }
  196. if(!empty($pageInfo->filter->order->value)){
  197. $query .= ' ORDER BY '.$pageInfo->filter->order->value.' '.$pageInfo->filter->order->dir;
  198. }
  199. $db->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  200. $rows = $db->loadObjectList();
  201. $queryWhere = 'SELECT COUNT(a.subid) FROM #__acymailing_subscriber as a';
  202. if(!empty($filters)){
  203. $queryWhere .= ' LEFT JOIN #__users as b on a.userid = b.id';
  204. $queryWhere .= ' WHERE ('.implode(') AND (',$filters).')';
  205. }
  206. $db->setQuery($queryWhere);
  207. $pageInfo->elements->total = $db->loadResult();
  208. if(!empty($pageInfo->search)){
  209. $rows = acymailing::search($pageInfo->search,$rows);
  210. }
  211. $pageInfo->elements->page = count($rows);
  212. jimport('joomla.html.pagination');
  213. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  214. $this->assignRef('rows',$rows);
  215. $this->assignRef('pageInfo',$pageInfo);
  216. $this->assignRef('pagination',$pagination);
  217. }
  218. function form(){
  219. $subid = acymailing::getCID('subid');
  220. $db =& JFactory::getDBO();
  221. if(!empty($subid)){
  222. $subscriberClass = acymailing::get('class.subscriber');
  223. $subscriber = $subscriberClass->getFull($subid);
  224. $subscription = $subscriberClass->getSubscription($subid);
  225. }else{
  226. $listType = acymailing::get('class.list');
  227. $subscription = $listType->getLists();
  228. $subscriber = null;
  229. $subscriber->created = time();
  230. $subscriber->html = 1;
  231. $subscriber->confirmed = 1;
  232. $subscriber->blocked = 0;
  233. $subscriber->accept = 1;
  234. $subscriber->enabled = 1;
  235. $iphelper = acymailing::get('helper.user');
  236. $subscriber->ip = $iphelper->getIP();
  237. }
  238. acymailing::setTitle(JText::_('ACY_USER'),'user','subscriber&task=edit&subid='.$subid);
  239. $bar = & JToolBar::getInstance('toolbar');
  240. if(acymailing::level(3)){
  241. $fieldsClass = acymailing::get('class.fields');
  242. $this->assignRef('fieldsClass',$fieldsClass);
  243. $this->assignRef('extraFields',$fieldsClass->getFields('backend',$subscriber));
  244. }
  245. if(!empty($subid) && acymailing::level(2)){
  246. $bar->appendButton( 'Popup', 'send', JText::_('SEND'), "index.php?option=com_acymailing&ctrl=send&task=addqueue&tmpl=component&subid=".$subid);
  247. JToolBarHelper::divider();
  248. $query = 'SELECT a.date, a.mailid, b.subject, b.alias, a.urlid, a.click, c.name as urlname, c.url';
  249. $query .= ' FROM '.acymailing::table('urlclick').' as a';
  250. $query .= ' LEFT JOIN '.acymailing::table('mail').' as b on a.mailid = b.mailid';
  251. $query .= ' LEFT JOIN '.acymailing::table('url').' as c on a.urlid = c.urlid';
  252. $query .= ' WHERE a.subid = '.intval($subid).' ORDER BY a.date DESC LIMIT 30';
  253. $db->setQuery($query);
  254. $clicks = $db->loadObjectList();
  255. $this->assignRef('clicks',$clicks);
  256. }
  257. if(!empty($subid)){
  258. $query = 'SELECT a.`mailid`, a.`html`, a.`sent`, a.`senddate`,a.`open`, a.`opendate`, a.`bounce`, a.`fail`,b.`subject`,b.`alias`';
  259. $query .= ' FROM `#__acymailing_userstats` as a';
  260. $query .= ' LEFT JOIN '.acymailing::table('mail').' as b on a.mailid = b.mailid';
  261. $query .= ' WHERE a.subid = '.intval($subid).' ORDER BY a.senddate DESC LIMIT 30';
  262. $db->setQuery($query);
  263. $open = $db->loadObjectList();
  264. $this->assignRef('open',$open);
  265. }
  266. if(!empty($subscriber->userid)){
  267. if(file_exists(ACYMAILING_ROOT.'components'.DS.'com_comprofiler'.DS.'comprofiler.php')){
  268. $editLink = 'index.php?option=com_comprofiler&task=edit&cid[]=';
  269. }elseif(version_compare(JVERSION,'1.6.0','<')){
  270. $editLink = 'index.php?option=com_users&task=edit&cid[]=';
  271. }else{
  272. $editLink = 'index.php?option=com_users&task=user.edit&id=';
  273. }
  274. $bar->appendButton( 'Link', 'edit', JText::_('EDIT_JOOMLA_USER'), $editLink.$subscriber->userid );
  275. JToolBarHelper::spacer();
  276. }
  277. JToolBarHelper::save();
  278. JToolBarHelper::apply();
  279. JToolBarHelper::cancel();
  280. JToolBarHelper::divider();
  281. $bar->appendButton( 'Pophelp','subscriber-form');
  282. $filters = null;
  283. $quickstatusType = acymailing::get('type.statusquick');
  284. $filters->statusquick = $quickstatusType->display('statusquick');
  285. $this->assignRef('subscriber',$subscriber);
  286. $this->assignRef('toggleClass',acymailing::get('helper.toggle'));
  287. $this->assignRef('subscription',$subscription);
  288. $this->assignRef('filters',$filters);
  289. $this->assignRef('statusType',acymailing::get('type.status'));
  290. }
  291. }