2 /*********************************************************************************
3 * SugarCRM is a customer relationship management program developed by
4 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
6 * This program is free software; you can redistribute it and/or modify it under
7 * the terms of the GNU Affero General Public License version 3 as published by the
8 * Free Software Foundation with the addition of the following permission added
9 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
11 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13 * This program is distributed in the hope that it will be useful, but WITHOUT
14 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
18 * You should have received a copy of the GNU Affero General Public License along with
19 * this program; if not, see http://www.gnu.org/licenses or write to the Free
20 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
23 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
24 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26 * The interactive user interfaces in modified source and object code versions
27 * of this program must display Appropriate Legal Notices, as required under
28 * Section 5 of the GNU Affero General Public License version 3.
30 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31 * these Appropriate Legal Notices must retain the display of the "Powered by
32 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
33 * technical reasons, the Appropriate Legal Notices must display the words
34 * "Powered by SugarCRM".
35 ********************************************************************************/
37 require_once('include/MVC/View/SugarView.php');
39 require_once('include/ListView/ListViewSmarty.php');
41 require_once('modules/MySettings/StoreQuery.php');
42 class ViewList extends SugarView{
65 function listViewPrepare(){
66 $module = $GLOBALS['module'];
68 $metadataFile = $this->getMetaDataFile();
70 if( !file_exists($metadataFile) )
71 sugar_die($GLOBALS['app_strings']['LBL_NO_ACTION'] );
73 require_once($metadataFile);
74 $this->listViewDefs = $listViewDefs;
76 if(!empty($this->bean->object_name) && isset($_REQUEST[$module.'2_'.strtoupper($this->bean->object_name).'_offset'])) {//if you click the pagination button, it will poplate the search criteria here
77 if(!empty($_REQUEST['current_query_by_page'])) {//The code support multi browser tabs pagination
78 $blockVariables = array('mass', 'uid', 'massupdate', 'delete', 'merge', 'selectCount', 'request_data', 'current_query_by_page',$module.'2_'.strtoupper($this->bean->object_name).'_ORDER_BY' );
79 if(isset($_REQUEST['lvso'])){
80 $blockVariables[] = 'lvso';
82 $current_query_by_page = unserialize(base64_decode($_REQUEST['current_query_by_page']));
83 foreach($current_query_by_page as $search_key=>$search_value) {
84 if($search_key != $module.'2_'.strtoupper($this->bean->object_name).'_offset' && !in_array($search_key, $blockVariables)) {
85 if (!is_array($search_value)) {
86 $_REQUEST[$search_key] = $GLOBALS['db']->quoteForEmail($search_value);
89 foreach ($search_value as $key=>&$val) {
90 $val = $GLOBALS['db']->quoteForEmail($val);
92 $_REQUEST[$search_key] = $search_value;
99 if(!empty($_REQUEST['saved_search_select'])) {
100 if ($_REQUEST['saved_search_select']=='_none' || !empty($_REQUEST['button'])) {
101 $_SESSION['LastSavedView'][$_REQUEST['module']] = '';
102 unset($_REQUEST['saved_search_select']);
103 unset($_REQUEST['saved_search_select_name']);
105 //use the current search module, or the current module to clear out layout changes
106 if(!empty($_REQUEST['search_module']) || !empty($_REQUEST['module'])){
107 $mod = !empty($_REQUEST['search_module']) ? $_REQUEST['search_module'] : $_REQUEST['module'];
108 global $current_user;
109 //Reset the current display columns to default.
110 $current_user->setPreference('ListViewDisplayColumns', array(), 0, $mod);
113 else if(empty($_REQUEST['button']) && (empty($_REQUEST['clear_query']) || $_REQUEST['clear_query']!='true')) {
114 $this->saved_search = loadBean('SavedSearch');
115 $this->saved_search->retrieveSavedSearch($_REQUEST['saved_search_select']);
116 $this->saved_search->populateRequest();
119 $this->storeQuery = new StoreQuery();
120 if(!isset($_REQUEST['query'])){
121 $this->storeQuery->loadQuery($this->module);
122 $this->storeQuery->populateRequest();
124 $this->storeQuery->saveFromRequest($this->module);
127 $this->seed = $this->bean;
129 $displayColumns = array();
130 if(!empty($_REQUEST['displayColumns'])) {
131 foreach(explode('|', $_REQUEST['displayColumns']) as $num => $col) {
132 if(!empty($this->listViewDefs[$module][$col]))
133 $displayColumns[$col] = $this->listViewDefs[$module][$col];
137 foreach($this->listViewDefs[$module] as $col => $this->params) {
138 if(!empty($this->params['default']) && $this->params['default'])
139 $displayColumns[$col] = $this->params;
142 $this->params = array('massupdate' => true);
143 if(!empty($_REQUEST['orderBy'])) {
144 $this->params['orderBy'] = $_REQUEST['orderBy'];
145 $this->params['overrideOrder'] = true;
146 if(!empty($_REQUEST['sortOrder'])) $this->params['sortOrder'] = $_REQUEST['sortOrder'];
148 $this->lv->displayColumns = $displayColumns;
150 $this->seed = $this->seed;
151 $this->module = $module;
153 $this->prepareSearchForm();
155 if(isset($this->options['show_title']) && $this->options['show_title']) {
156 $moduleName = isset($this->seed->module_dir) ? $this->seed->module_dir : $GLOBALS['mod_strings']['LBL_MODULE_NAME'];
157 echo $this->getModuleTitle(true);
161 function listViewProcess(){
162 $this->processSearchForm();
163 $this->lv->searchColumns = $this->searchForm->searchColumns;
167 if(empty($_REQUEST['search_form_only']) || $_REQUEST['search_form_only'] == false){
168 $this->lv->ss->assign("SEARCH",true);
169 $this->lv->setup($this->seed, 'include/ListView/ListViewGeneric.tpl', $this->where, $this->params);
170 $savedSearchName = empty($_REQUEST['saved_search_select_name']) ? '' : (' - ' . $_REQUEST['saved_search_select_name']);
171 echo $this->lv->display();
174 function prepareSearchForm(){
175 $this->searchForm = null;
178 $view = 'basic_search';
179 if(!empty($_REQUEST['search_form_view']) && $_REQUEST['search_form_view'] == 'advanced_search')
180 $view = $_REQUEST['search_form_view'];
181 $this->headers = true;
182 if(!empty($_REQUEST['search_form_only']) && $_REQUEST['search_form_only'])
183 $this->headers = false;
184 elseif(!isset($_REQUEST['search_form']) || $_REQUEST['search_form'] != 'false') {
185 if(isset($_REQUEST['searchFormTab']) && $_REQUEST['searchFormTab'] == 'advanced_search') {
186 $view = 'advanced_search';
188 $view = 'basic_search';
192 $this->use_old_search = true;
193 if ((file_exists('modules/' . $this->module . '/SearchForm.html')
194 && !file_exists('modules/' . $this->module . '/metadata/searchdefs.php'))
195 || (file_exists('custom/modules/' . $this->module . '/SearchForm.html')
196 && !file_exists('custom/modules/' . $this->module . '/metadata/searchdefs.php'))){
197 require_once('include/SearchForm/SearchForm.php');
198 $this->searchForm = new SearchForm($this->module, $this->seed);
200 $this->use_old_search = false;
201 require_once('include/SearchForm/SearchForm2.php');
203 if(file_exists('custom/modules/'.$this->module.'/metadata/metafiles.php')){
204 require('custom/modules/'.$this->module.'/metadata/metafiles.php');
205 }elseif(file_exists('modules/'.$this->module.'/metadata/metafiles.php')){
206 require('modules/'.$this->module.'/metadata/metafiles.php');
209 /* if(!empty($metafiles[$this->module]['searchdefs']))
210 require_once($metafiles[$this->module]['searchdefs']);
211 elseif(file_exists('modules/'.$this->module.'/metadata/searchdefs.php'))
212 require_once('modules/'.$this->module.'/metadata/searchdefs.php');
215 if (file_exists('custom/modules/'.$this->module.'/metadata/searchdefs.php'))
217 require_once('custom/modules/'.$this->module.'/metadata/searchdefs.php');
219 elseif (!empty($metafiles[$this->module]['searchdefs']))
221 require_once($metafiles[$this->module]['searchdefs']);
223 elseif (file_exists('modules/'.$this->module.'/metadata/searchdefs.php'))
225 require_once('modules/'.$this->module.'/metadata/searchdefs.php');
229 if(!empty($metafiles[$this->module]['searchfields']))
230 require_once($metafiles[$this->module]['searchfields']);
231 elseif(file_exists('modules/'.$this->module.'/metadata/SearchFields.php'))
232 require_once('modules/'.$this->module.'/metadata/SearchFields.php');
234 if(file_exists('custom/modules/'.$this->module.'/metadata/SearchFields.php')){
235 require_once('custom/modules/'.$this->module.'/metadata/SearchFields.php');
239 $this->searchForm = new SearchForm($this->seed, $this->module, $this->action);
240 $this->searchForm->setup($searchdefs, $searchFields, 'include/SearchForm/tpls/SearchFormGeneric.tpl', $view, $this->listViewDefs);
241 $this->searchForm->lv = $this->lv;
244 function processSearchForm(){
245 if(isset($_REQUEST['query']))
248 if(!empty($_SERVER['HTTP_REFERER']) && preg_match('/action=EditView/', $_SERVER['HTTP_REFERER'])) { // from EditView cancel
249 $this->searchForm->populateFromArray($this->storeQuery->query);
252 $this->searchForm->populateFromRequest();
255 $where_clauses = $this->searchForm->generateSearchWhere(true, $this->seed->module_dir);
257 if (count($where_clauses) > 0 )$this->where = '('. implode(' ) AND ( ', $where_clauses) . ')';
258 $GLOBALS['log']->info("List View Where Clause: $this->where");
260 if($this->use_old_search){
263 $this->searchForm->setup();
264 $this->searchForm->displayBasic($this->headers);
266 case 'advanced_search':
267 $this->searchForm->setup();
268 $this->searchForm->displayAdvanced($this->headers);
271 echo $this->searchForm->displaySavedViews($this->listViewDefs, $this->lv, $this->headers);
275 echo $this->searchForm->display($this->headers);
278 function preDisplay(){
279 $this->lv = new ListViewSmarty();
282 if(!$this->bean || !$this->bean->ACLAccess('list')){
283 ACLController::displayNoAccess();
285 $this->listViewPrepare();
286 $this->listViewProcess();