PageRenderTime 45ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/Quản lý website bán mỹ phẩm PHP/components/com_acymailing/views/archive/view.html.php

https://gitlab.com/phamngsinh/baitaplon_sinhvien
PHP | 299 lines | 294 code | 1 blank | 4 comment | 57 complexity | 40769014913eba5ba4865164549e6518 MD5 | raw file
  1. <?php
  2. /**
  3. * @copyright Copyright (C) 2009-2012 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 archiveViewArchive extends JView
  10. {
  11. function display($tpl = null)
  12. {
  13. $function = $this->getLayout();
  14. if(method_exists($this,$function)) $this->$function();
  15. parent::display($tpl);
  16. }
  17. function forward(){
  18. return $this->view();
  19. }
  20. function listing(){
  21. global $Itemid;
  22. $app = JFactory::getApplication();
  23. $my = JFactory::getUser();
  24. $pathway = $app->getPathway();
  25. $values = new stdClass();
  26. $jsite = JFactory::getApplication('site');
  27. $menus = $jsite->getMenu();
  28. $menu = $menus->getActive();
  29. $config = acymailing_config();
  30. if(empty($menu) AND !empty($Itemid)){
  31. $menus->setActive($Itemid);
  32. $menu = $menus->getItem($Itemid);
  33. }
  34. $myItem = empty($Itemid) ? '' : '&Itemid='.$Itemid;
  35. $this->assignRef('item',$myItem);
  36. if (is_object( $menu )) {
  37. jimport('joomla.html.parameter');
  38. $menuparams = new JParameter( $menu->params );
  39. }
  40. $pageInfo = new stdClass();
  41. $pageInfo->filter = new stdClass();
  42. $pageInfo->filter->order = new stdClass();
  43. $pageInfo->limit = new stdClass();
  44. $pageInfo->elements = new stdClass();
  45. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName();
  46. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.senddate','cmd' );
  47. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  48. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  49. $pageInfo->search = JString::strtolower( $pageInfo->search );
  50. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  51. $pageInfo->limit->start = JRequest::getInt('limitstart',0);
  52. $listClass = acymailing_get('class.list');
  53. $listid = acymailing_getCID('listid');
  54. if(empty($listid) AND !empty($menuparams)){
  55. $listid = $menuparams->get('listid');
  56. }
  57. if(empty($listid) AND acymailing_level(3)){
  58. $listClass = acymailing_get('class.list');
  59. $allAllowedLists = $listClass->getFrontendLists();
  60. if(!empty($allAllowedLists)){
  61. $firstList = reset($allAllowedLists);
  62. $listid = $firstList->listid;
  63. JRequest::setVar('listid',$listid);
  64. }
  65. }
  66. if(empty($listid)){
  67. return JError::raiseError( 404, 'Mailing List not found' );
  68. }
  69. $oneList = $listClass->get($listid);
  70. if(empty($oneList->listid)){
  71. return JError::raiseError( 404, 'Mailing List not found : '.$listid );
  72. }
  73. $access = new stdClass();
  74. $access->frontEndManament = false;
  75. $access->frontEndAccess = true;
  76. if(!$access->frontEndManament AND (!$oneList->published OR !$oneList->visible OR !$access->frontEndAccess)){
  77. if(empty($my->id)){
  78. $usercomp = version_compare(JVERSION,'1.6.0','<') ? 'com_user' : 'com_users';
  79. $uri = JFactory::getURI();
  80. $url = 'index.php?option='.$usercomp.'&view=login&return='.base64_encode($uri->toString());
  81. $app->redirect($url, JText::_('ACY_NOTALLOWED') );
  82. return false;
  83. }else{
  84. $app->enqueueMessage(JText::_('ACY_NOTALLOWED'),'error');
  85. $app->redirect(acymailing_completeLink('lists',false,true));
  86. return false;
  87. }
  88. }
  89. if($config->get('open_popup',1)) JHTML::_('behavior.modal','a.modal');
  90. if(!empty($menuparams)){
  91. $values->suffix = $menuparams->get('pageclass_sfx','');
  92. $values->page_title = $menuparams->get('page_title');
  93. $values->show_page_title = $menuparams->get('show_page_title',1);
  94. }else{
  95. $values->suffix = '';
  96. $values->show_page_title = 1;
  97. }
  98. $values->show_description = $config->get('show_description',1);
  99. $values->show_headings = $config->get('show_headings',1);
  100. $values->show_senddate = $config->get('show_senddate',1);
  101. $values->show_colnumber = $config->get('show_colnumber',1);
  102. $values->show_receiveemail = $config->get('show_receiveemail',0) && acymailing_level(1);
  103. $values->filter = $config->get('show_filter',1);
  104. if(empty($values->page_title)) $values->page_title = $oneList->name;
  105. if(empty($menuparams)){
  106. $pathway->addItem(JText::_('MAILING_LISTS'),acymailing_completeLink('lists'));
  107. $pathway->addItem($values->page_title);
  108. }elseif(!$menuparams->get('listid')){
  109. $pathway->addItem($values->page_title);
  110. }
  111. $document = JFactory::getDocument();
  112. $document->setTitle( $values->page_title );
  113. $link = '&format=feed&limitstart=';
  114. if($config->get('acyrss_format') == 'rss' || $config->get('acyrss_format') == 'both'){
  115. $attribs = array('type' => 'application/rss+xml', 'title' => 'RSS 2.0');
  116. $document->addHeadLink(JRoute::_($link.'&type=rss'), 'alternate', 'rel', $attribs);
  117. }
  118. if($config->get('acyrss_format') == 'atom' || $config->get('acyrss_format') == 'both'){
  119. $attribs = array('type' => 'application/atom+xml', 'title' => 'Atom 1.0');
  120. $document->addHeadLink(JRoute::_($link.'&type=atom'), 'alternate', 'rel', $attribs);
  121. }
  122. $db = JFactory::getDBO();
  123. $searchMap = array('a.mailid','a.subject','a.alias');
  124. $filters = array();
  125. if(!empty($pageInfo->search)){
  126. $searchVal = '\'%'.$db->getEscaped($pageInfo->search,true).'%\'';
  127. $filters[] = implode(" LIKE $searchVal OR ",$searchMap)." LIKE $searchVal";
  128. }
  129. $filters[] = 'a.type = \'news\'';
  130. if(!$access->frontEndManament){
  131. $filters[] = 'a.published = 1';
  132. $filters[] = 'a.visible = 1';
  133. }
  134. $filters[] = 'c.listid = '.$oneList->listid;
  135. $selection = array_merge($searchMap,array('a.senddate','a.created','a.visible','a.published','a.fromname','a.fromemail','a.replyname','a.replyemail','a.userid'));
  136. $query = 'SELECT '.implode(',',$selection);
  137. $query .= ' FROM '.acymailing_table('listmail').' as c';
  138. $query .= ' JOIN '.acymailing_table('mail').' as a on a.mailid = c.mailid ';
  139. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  140. $query .= ' ORDER BY '.acymailing_secureField($pageInfo->filter->order->value).' '.acymailing_secureField($pageInfo->filter->order->dir).', c.mailid DESC';
  141. $db->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  142. $rows = $db->loadObjectList();
  143. $pageInfo->elements->page = count($rows);
  144. if(!empty($pageInfo->search)){
  145. $rows = acymailing_search($pageInfo->search,$rows);
  146. }
  147. if($pageInfo->limit->value > $pageInfo->elements->page){
  148. $pageInfo->elements->total = $pageInfo->limit->start + $pageInfo->elements->page;
  149. }else{
  150. $queryCount = 'SELECT COUNT(c.mailid) FROM '.acymailing_table('listmail').' as c';
  151. $queryCount .= ' JOIN '.acymailing_table('mail').' as a on a.mailid = c.mailid ';
  152. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  153. $db->setQuery($queryCount);
  154. $pageInfo->elements->total = $db->loadResult();
  155. }
  156. jimport('joomla.html.pagination');
  157. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  158. $js = 'function tableOrdering( order, dir, task ){
  159. var form = document.adminForm;
  160. form.filter_order.value = order;
  161. form.filter_order_Dir.value = dir;
  162. document.adminForm.submit( task );
  163. }
  164. function changeReceiveEmail(checkedbox){
  165. var form = document.adminForm;
  166. if(checkedbox){
  167. form.nbreceiveemail.value++;
  168. }else{
  169. form.nbreceiveemail.value--;
  170. }
  171. if(form.nbreceiveemail.value > 0 ){
  172. document.getElementById(\'receiveemailbox\').className = \'receiveemailbox receiveemailbox_visible\';
  173. }else{
  174. document.getElementById(\'receiveemailbox\').className = \'receiveemailbox receiveemailbox_hidden\';
  175. }
  176. }
  177. ';
  178. $doc = JFactory::getDocument();
  179. $doc->addScriptDeclaration( $js);
  180. $this->assignRef('access',$access);
  181. $this->assignRef('rows',$rows);
  182. $this->assignRef('values',$values);
  183. $this->assignRef('list',$oneList);
  184. $this->assignRef('pagination',$pagination);
  185. $this->assignRef('pageInfo',$pageInfo);
  186. $this->assignRef('config',$config);
  187. $this->assignRef('my',$my);
  188. }
  189. function view(){
  190. global $Itemid;
  191. $app = JFactory::getApplication();
  192. $pathway = $app->getPathway();
  193. $my = JFactory::getUser();
  194. $frontEndManagement = false;
  195. $listid = acymailing_getCID('listid');
  196. if(empty($listid)){
  197. $jsite = JFactory::getApplication('site');
  198. $menus = $jsite->getMenu();
  199. $menu = $menus->getActive();
  200. if(empty($menu) AND !empty($Itemid)){
  201. $menus->setActive($Itemid);
  202. $menu = $menus->getItem($Itemid);
  203. }
  204. if (is_object( $menu )) {
  205. jimport('joomla.html.parameter');
  206. $menuparams = new JParameter( $menu->params );
  207. }
  208. if(!empty($menuparams)){
  209. $listid = $menuparams->get('listid');
  210. $document = JFactory::getDocument();
  211. if ($menuparams->get('menu-meta_description')) $document->setDescription($menuparams->get('menu-meta_description'));
  212. if ($menuparams->get('menu-meta_keywords')) $document->setMetadata('keywords',$menuparams->get('menu-meta_keywords'));
  213. if ($menuparams->get('robots')) $document->setMetadata('robots',$menuparams->get('robots'));
  214. if ($menuparams->get('page_title')) $document->setTitle($menuparams->get('page_title'));
  215. }
  216. }
  217. if(!empty($listid)){
  218. $listClass = acymailing_get('class.list');
  219. $oneList = $listClass->get($listid);
  220. if(!empty($oneList->visible) AND $oneList->published AND (empty($menuparams) || !$menuparams->get('listid'))){
  221. $pathway->addItem($oneList->name,acymailing_completeLink('archive&listid='.$oneList->listid.':'.$oneList->alias));
  222. }
  223. if(!empty($oneList->listid) AND acymailing_level(3)){
  224. if(!empty($my->id) AND (int)$my->id == (int)$oneList->userid){
  225. $frontEndManagement = true;
  226. }
  227. if(!empty($my->id)){
  228. if($oneList->access_manage == 'all' OR acymailing_isAllowed($oneList->access_manage)){
  229. $frontEndManagement = true;
  230. }
  231. }
  232. }
  233. }
  234. $mailid = JRequest::getString('mailid','nomailid');
  235. if(empty($mailid)) return JError::raiseError( 404, 'You can not preview a Newsletter-template, please create a Newsletter from your template');
  236. if($mailid == 'nomailid'){
  237. $db = JFactory::getDBO();
  238. $query = 'SELECT m.`mailid` FROM `#__acymailing_list` as l LEFT JOIN `#__acymailing_listmail` as lm ON l.listid=lm.listid LEFT JOIN `#__acymailing_mail` as m on lm.mailid = m.mailid';
  239. $query .= ' WHERE l.`visible` = 1 AND l.`published` = 1 AND m.`visible`= 1 AND m.`published` = 1';
  240. if(!empty($listid)) $query .= ' AND l.`listid` = '.(int) $listid;
  241. $query .= ' ORDER BY m.`mailid` DESC LIMIT 1';
  242. $db->setQuery($query);
  243. $mailid = $db->loadResult();
  244. }
  245. $mailid = intval($mailid);
  246. if(empty($mailid)) return JError::raiseError( 404, 'Newsletter not found');
  247. $access_sub = true;
  248. $mailClass = acymailing_get('helper.mailer');
  249. $mailClass->loadedToSend = false;
  250. $oneMail = $mailClass->load($mailid);
  251. if(empty($oneMail->mailid)){
  252. return JError::raiseError( 404, 'Newsletter not found : '.$mailid );
  253. }
  254. if(!$frontEndManagement AND (!$access_sub OR !$oneMail->published OR !$oneMail->visible)){
  255. $key = JRequest::getString('key');
  256. if(empty($key) OR $key !== $oneMail->key){
  257. $reason = (!$oneMail->published) ? 'Newsletter not published' : (!$oneMail->visible ? 'Newsletter not visible' : (!$access_sub ? 'Access not allowed' : ''));
  258. $app->enqueueMessage('You can not have access to this e-mail : '.$reason,'error');
  259. $app->redirect(acymailing_completeLink('lists',false,true));
  260. return false;
  261. }
  262. }
  263. $subkeys = JRequest::getString('subid',JRequest::getString('sub'));
  264. if(!empty($subkeys)){
  265. $db = JFactory::getDBO();
  266. $subid = intval(substr($subkeys,0,strpos($subkeys,'-')));
  267. $subkey = substr($subkeys,strpos($subkeys,'-')+1);
  268. $db->setQuery('SELECT * FROM '.acymailing_table('subscriber').' WHERE `subid` = '.$db->Quote($subid).' AND `key` = '.$db->Quote($subkey).' LIMIT 1');
  269. $receiver = $db->loadObject();
  270. }
  271. if(empty($receiver) AND !empty($my->email)){
  272. $userClass = acymailing_get('class.subscriber');
  273. $receiver = $userClass->get($my->email);
  274. }
  275. if(empty($receiver)){
  276. $receiver = new stdClass();
  277. $receiver->name = JText::_('VISITOR');
  278. }
  279. $oneMail->sendHTML = true;
  280. $mailClass->dispatcher->trigger('acymailing_replaceusertags',array(&$oneMail,&$receiver,false));
  281. $pathway->addItem($oneMail->subject);
  282. $document = JFactory::getDocument();
  283. $document->setTitle( $oneMail->subject );
  284. if (!empty($oneMail->metadesc)) {
  285. $document->setDescription( $oneMail->metadesc );
  286. }
  287. if (!empty($oneMail->metakey)) {
  288. $document->setMetadata('keywords', $oneMail->metakey);
  289. }
  290. $this->assignRef('mail',$oneMail);
  291. $this->assignRef('frontEndManagement',$frontEndManagement);
  292. $this->assignRef('list',$oneList);
  293. $config =& acymailing_config();
  294. $this->assignRef('config',$config);
  295. $this->assignRef('my',$my);
  296. $this->assignRef('receiver',$receiver);
  297. }
  298. }