]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/Popups/PopupSmarty.php
Release 6.4.0
[Github/sugarcrm.git] / include / Popups / PopupSmarty.php
1 <?php
2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4  * SugarCRM Community Edition is a customer relationship management program developed by
5  * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
6  * 
7  * This program is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU Affero General Public License version 3 as published by the
9  * Free Software Foundation with the addition of the following permission added
10  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13  * 
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
17  * details.
18  * 
19  * You should have received a copy of the GNU Affero General Public License along with
20  * this program; if not, see http://www.gnu.org/licenses or write to the Free
21  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301 USA.
23  * 
24  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26  * 
27  * The interactive user interfaces in modified source and object code versions
28  * of this program must display Appropriate Legal Notices, as required under
29  * Section 5 of the GNU Affero General Public License version 3.
30  * 
31  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32  * these Appropriate Legal Notices must retain the display of the "Powered by
33  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34  * technical reasons, the Appropriate Legal Notices must display the words
35  * "Powered by SugarCRM".
36  ********************************************************************************/
37
38 require_once('include/ListView/ListViewSmarty.php');
39
40 require_once('include/TemplateHandler/TemplateHandler.php');
41 require_once('include/SearchForm/SearchForm2.php');
42 define("NUM_COLS", 2);
43 class PopupSmarty extends ListViewSmarty{
44
45         var $contextMenus = false;
46         var $export = false;
47         var $mailmerge = false;
48         var $mergeduplicates = false;
49         var $quickViewLinks = false;
50         var $multiSelect = false;
51         var $headerTpl;
52     var $footerTpl;
53     var $th;
54     var $tpl;
55     var $view;
56     var $field_defs;
57     var $formData;
58     var $_popupMeta;
59     var $_create = false;
60     var $searchdefs = array();
61     var $listviewdefs = array();
62     var $searchFields = array();
63     var $customFieldDefs;
64     var $filter_fields = array();
65     //rrs
66     var $searchForm;
67     var $module;
68     var $massUpdateData = '';
69
70         function PopupSmarty($seed, $module){
71                 parent::ListViewSmarty();
72                 $this->th = new TemplateHandler();
73                 $this->th->loadSmarty();
74                 $this->seed = $seed;
75                 $this->view = 'Popup';
76                 $this->module = $module;
77                 $this->searchForm = new SearchForm($this->seed, $this->module);
78                 $this->th->deleteTemplate($module, $this->view);
79
80         }
81
82     /**
83      * Assign several arrow image attributes to TemplateHandler smarty. Such as width, height, etc.
84      * 
85      * @return void
86      */
87     function processArrowVars()
88     {
89         $pathParts = pathinfo(SugarThemeRegistry::current()->getImageURL('arrow.gif',false));
90
91         list($width,$height) = getimagesize($pathParts['dirname'].'/'.$pathParts['basename']);
92
93         $this->th->ss->assign('arrowExt', $pathParts['extension']);
94         $this->th->ss->assign('arrowWidth', $width);
95         $this->th->ss->assign('arrowHeight', $height);
96         $this->th->ss->assign('arrowAlt', translate('LBL_SORT'));
97     }
98
99         /**
100      * Processes the request. Calls ListViewData process. Also assigns all lang strings, export links,
101      * This is called from ListViewDisplay
102      *
103      * @param file file Template file to use
104      * @param data array from ListViewData
105      * @param html_var string the corresponding html var in xtpl per row
106      *
107      */
108         function process($file, $data, $htmlVar) {
109
110                 global $odd_bg, $even_bg, $hilite_bg, $click_bg, $app_strings;
111                 parent::process($file, $data, $htmlVar);
112
113                 $this->tpl = $file;
114                 $this->data = $data;
115
116         $totalWidth = 0;
117         foreach($this->displayColumns as $name => $params) {
118             $totalWidth += $params['width'];
119         }
120         $adjustment = $totalWidth / 100;
121
122         $contextMenuObjectsTypes = array();
123         foreach($this->displayColumns as $name => $params) {
124             $this->displayColumns[$name]['width'] = round($this->displayColumns[$name]['width'] / $adjustment, 2);
125             // figure out which contextMenu objectsTypes are required
126             if(!empty($params['contextMenu']['objectType']))
127                 $contextMenuObjectsTypes[$params['contextMenu']['objectType']] = true;
128         }
129                 $this->th->ss->assign('displayColumns', $this->displayColumns);
130
131
132                 $this->th->ss->assign('bgHilite', $hilite_bg);
133                 $this->th->ss->assign('colCount', count($this->displayColumns) + 1);
134                 $this->th->ss->assign('htmlVar', strtoupper($htmlVar));
135                 $this->th->ss->assign('moduleString', $this->moduleString);
136         $this->th->ss->assign('editLinkString', $GLOBALS['app_strings']['LBL_EDIT_BUTTON']);
137         $this->th->ss->assign('viewLinkString', $GLOBALS['app_strings']['LBL_VIEW_BUTTON']);
138
139         //rrs
140         $this->searchForm->parsedView = 'popup_query_form';
141         $this->searchForm->displayType = 'popupView';
142                 $this->th->ss->assign('searchForm', $this->searchForm->display(false));
143         //rrs
144
145                 if($this->overlib) $this->th->ss->assign('overlib', true);
146                 if($this->export) $this->th->ss->assign('exportLink', $this->buildExportLink());
147                 $this->th->ss->assign('quickViewLinks', $this->quickViewLinks);
148                 if($this->mailMerge) $this->th->ss->assign('mergeLink', $this->buildMergeLink()); // still check for mailmerge access
149                 if($this->mergeduplicates) $this->th->ss->assign('mergedupLink', $this->buildMergeDuplicatesLink());
150
151
152                 if (!empty($_REQUEST['mode']) && strtoupper($_REQUEST['mode']) == 'MULTISELECT') {
153                         $this->multiSelect = true;
154                 }
155                 // handle save checks and stuff
156                 if($this->multiSelect) {
157                         $this->th->ss->assign('selectedObjectsSpan', $this->buildSelectedObjectsSpan());
158                         $this->th->ss->assign('multiSelectData', $this->getMultiSelectData());
159                         $this->th->ss->assign('MODE', "<input type='hidden' name='mode' value='MultiSelect'>");
160             $pageTotal = $this->data['pageData']['offsets']['next'] - $this->data['pageData']['offsets']['current'];
161             if($this->data['pageData']['offsets']['next'] < 0){ // If we are on the last page, 'next' is -1, which means we have to have a custom calculation
162                 $pageTotal = $this->data['pageData']['offsets']['total'] - $this->data['pageData']['offsets']['current'];
163             }
164                 $this->th->ss->assign('selectLink', $this->buildSelectLink('select_link', $this->data['pageData']['offsets']['total'], $pageTotal));
165                 }
166
167                 $this->processArrows($data['pageData']['ordering']);
168                 $this->th->ss->assign('prerow', $this->multiSelect);
169                 $this->th->ss->assign('rowColor', array('oddListRow', 'evenListRow'));
170                 $this->th->ss->assign('bgColor', array($odd_bg, $even_bg));
171         $this->th->ss->assign('contextMenus', $this->contextMenus);
172
173
174         if($this->contextMenus && !empty($contextMenuObjectsTypes)) {
175             $script = '';
176             $cm = new contextMenu();
177             foreach($contextMenuObjectsTypes as $type => $value) {
178                 $cm->loadFromFile($type);
179                 $script .= $cm->getScript();
180                 $cm->menuItems = array(); // clear menuItems out
181             }
182             $this->th->ss->assign('contextMenuScript', $script);
183         }
184
185         //rrs
186         $this->_build_field_defs();
187
188             // arrow image attributes
189             $this->processArrowVars();
190         }
191
192         /*
193          * Display the Smarty template.  Here we are using the TemplateHandler for caching per the module.
194          */
195         function display($end = true) {
196         global $app_strings;
197
198         if(!is_file(sugar_cached("jsLanguage/{$GLOBALS['current_language']}.js"))) {
199             require_once('include/language/jsLanguage.php');
200             jsLanguage::createAppStringsCache($GLOBALS['current_language']);
201         }
202         $jsLang = getVersionedScript("cache/jsLanguage/{$GLOBALS['current_language']}.js",  $GLOBALS['sugar_config']['js_lang_version']);
203
204         $this->th->ss->assign('data', $this->data['data']);
205                 $this->data['pageData']['offsets']['lastOffsetOnPage'] = $this->data['pageData']['offsets']['current'] + count($this->data['data']);
206                 $this->th->ss->assign('pageData', $this->data['pageData']);
207
208         $navStrings = array('next' => $GLOBALS['app_strings']['LNK_LIST_NEXT'],
209                             'previous' => $GLOBALS['app_strings']['LNK_LIST_PREVIOUS'],
210                             'end' => $GLOBALS['app_strings']['LNK_LIST_END'],
211                             'start' => $GLOBALS['app_strings']['LNK_LIST_START'],
212                             'of' => $GLOBALS['app_strings']['LBL_LIST_OF']);
213         $this->th->ss->assign('navStrings', $navStrings);
214
215
216                 $associated_row_data = array();
217                 
218                 //C.L. - Bug 44324 - Override the NAME entry to not display salutation so that the data returned from the popup can be searched on correctly
219                 $searchNameOverride = !empty($this->seed) && $this->seed instanceof Person && (isset($this->data['data'][0]['FIRST_NAME']) && isset($this->data['data'][0]['LAST_NAME'])) ? true : false;
220                 
221                 global $locale;
222                 foreach($this->data['data'] as $val)
223                 {
224                         $associated_row_data[$val['ID']] = $val;
225                         if($searchNameOverride)
226                         {
227                            $associated_row_data[$val['ID']]['NAME'] = $locale->getLocaleFormattedName($val['FIRST_NAME'], $val['LAST_NAME']);
228                         }
229                 }
230                 $is_show_fullname = showFullName() ? 1 : 0;
231                 $json = getJSONobj();
232                 $this->th->ss->assign('jsLang', $jsLang);
233                 $this->th->ss->assign('lang', substr($GLOBALS['current_language'], 0, 2));
234                 $this->th->ss->assign('headerTpl', 'include/Popups/tpls/header.tpl');
235         $this->th->ss->assign('footerTpl', 'include/Popups/tpls/footer.tpl');
236         $this->th->ss->assign('ASSOCIATED_JAVASCRIPT_DATA', 'var associated_javascript_data = '.$json->encode($associated_row_data). '; var is_show_fullname = '.$is_show_fullname.';');
237                 $this->th->ss->assign('module', $this->seed->module_dir);
238                 $request_data = empty($_REQUEST['request_data']) ? '' : $_REQUEST['request_data'];
239                 $this->th->ss->assign('request_data', $request_data);
240                 $this->th->ss->assign('fields', $this->fieldDefs);
241                 $this->th->ss->assign('formData', $this->formData);
242                 $this->th->ss->assign('APP', $GLOBALS['app_strings']);
243                 $this->th->ss->assign('MOD', $GLOBALS['mod_strings']);
244                 $this->th->ss->assign('popupMeta', $this->_popupMeta);
245         $this->th->ss->assign('current_query', base64_encode(serialize($_REQUEST)));
246                 $this->th->ss->assign('customFields', $this->customFieldDefs);
247                 $this->th->ss->assign('numCols', NUM_COLS);
248                 $this->th->ss->assign('massUpdateData', $this->massUpdateData);
249                 $this->th->ss->assign('sugarVersion', $GLOBALS['sugar_version']);
250         $this->th->ss->assign('should_process', $this->should_process);
251
252                 if($this->_create){
253                         $this->th->ss->assign('ADDFORM', $this->getQuickCreate());//$this->_getAddForm());
254                         $this->th->ss->assign('ADDFORMHEADER', $this->_getAddFormHeader());
255                         $this->th->ss->assign('object_name', $this->seed->object_name);
256                 }
257                 $this->th->ss->assign('LIST_HEADER', get_form_header($GLOBALS['mod_strings']['LBL_LIST_FORM_TITLE'], '', false));
258                 $this->th->ss->assign('SEARCH_FORM_HEADER', get_form_header($GLOBALS['mod_strings']['LBL_SEARCH_FORM_TITLE'], '', false));
259                 $str = $this->th->displayTemplate($this->seed->module_dir, $this->view, $this->tpl);
260                 return $str;
261         }
262
263         /*
264          * Setup up the smarty template. we added an extra step here to add the order by from the popupdefs.
265          */
266         function setup($file) {
267
268             if(isset($this->_popupMeta)){
269                         if(isset($this->_popupMeta['create']['formBase'])) {
270                                 require_once('modules/' . $this->seed->module_dir . '/' . $this->_popupMeta['create']['formBase']);
271                                 $this->_create = true;
272                         }
273                 }
274             if(!empty($this->_popupMeta['create'])){
275                         $formBase = new $this->_popupMeta['create']['formBaseClass']();
276                         if(isset($_REQUEST['doAction']) && $_REQUEST['doAction'] == 'save')
277                         {
278                                 //If it's a new record, set useRequired to false
279                                 $useRequired = empty($_REQUEST['id']) ? false : true;
280                                 $formBase->handleSave('', false, $useRequired);
281                         }
282                 }
283
284                 $params = array();
285                 if(!empty($this->_popupMeta['orderBy'])){
286                         $params['orderBy'] = $this->_popupMeta['orderBy'];
287                 }
288
289                 if(file_exists('custom/modules/'.$this->module.'/metadata/metafiles.php')){
290                         require('custom/modules/'.$this->module.'/metadata/metafiles.php');
291                 }elseif(file_exists('modules/'.$this->module.'/metadata/metafiles.php')){
292                         require('modules/'.$this->module.'/metadata/metafiles.php');
293                 }
294
295                 if(!empty($metafiles[$this->module]['searchfields'])) {
296                         require($metafiles[$this->module]['searchfields']);
297                 } elseif(file_exists('modules/'.$this->module.'/metadata/SearchFields.php')) {
298                         require('modules/'.$this->module.'/metadata/SearchFields.php');
299             }
300         $this->searchdefs[$this->module]['templateMeta']['maxColumns'] = 2;
301         $this->searchdefs[$this->module]['templateMeta']['widths']['label'] = 10;
302         $this->searchdefs[$this->module]['templateMeta']['widths']['field'] = 30;
303
304         $this->searchForm->view = 'PopupSearchForm';
305                 $this->searchForm->setup($this->searchdefs, $searchFields, 'include/SearchForm/tpls/SearchFormGenericAdvanced.tpl', 'advanced_search', $this->listviewdefs);
306
307                 $lv = new ListViewSmarty();
308                 $displayColumns = array();
309                 if(!empty($_REQUEST['displayColumns'])) {
310                     foreach(explode('|', $_REQUEST['displayColumns']) as $num => $col) {
311                         if(!empty($listViewDefs[$this->module][$col]))
312                             $displayColumns[$col] = $this->listviewdefs[$this->module][$col];
313                     }
314                 }
315                 else {
316                     foreach($this->listviewdefs[$this->module] as $col => $para) {
317                         if(!empty($para['default']) && $para['default'])
318                             $displayColumns[$col] = $para;
319                     }
320                 }
321                 $params['massupdate'] = true;
322                 if(!empty($_REQUEST['orderBy'])) {
323                     $params['orderBy'] = $_REQUEST['orderBy'];
324                     $params['overrideOrder'] = true;
325                     if(!empty($_REQUEST['sortOrder'])) $params['sortOrder'] = $_REQUEST['sortOrder'];
326                 }
327
328                 $lv->displayColumns = $displayColumns;
329         $this->searchForm->lv = $lv;
330         $this->searchForm->displaySavedSearch = false;
331
332
333         $this->searchForm->populateFromRequest('advanced_search');
334         $searchWhere = $this->_get_where_clause();
335         $this->searchColumns = $this->searchForm->searchColumns;
336         //parent::setup($this->seed, $file, $searchWhere, $params, 0, -1, $this->filter_fields);
337
338         $this->should_process = true;
339
340         if(isset($params['export'])) {
341           $this->export = $params['export'];
342         }
343         if(!empty($params['multiSelectPopup'])) {
344                   $this->multi_select_popup = $params['multiSelectPopup'];
345         }
346                 if(!empty($params['massupdate']) && $params['massupdate'] != false) {
347                         $this->show_mass_update_form = true;
348                         $this->mass = new MassUpdate();
349                         $this->mass->setSugarBean($this->seed);
350                         if(!empty($params['handleMassupdate']) || !isset($params['handleMassupdate'])) {
351                 $this->mass->handleMassUpdate();
352             }
353                 }
354
355         // create filter fields based off of display columns
356         if(empty($this->filter_fields) || $this->mergeDisplayColumns) {
357             foreach($this->displayColumns as $columnName => $def) {
358                $this->filter_fields[strtolower($columnName)] = true;
359                if(!empty($def['related_fields'])) {
360                     foreach($def['related_fields'] as $field) {
361                         //id column is added by query construction function. This addition creates duplicates
362                         //and causes issues in oracle. #10165
363                         if ($field != 'id') {
364                             $this->filter_fields[$field] = true;
365                         }
366                     }
367                 }
368                 if (!empty($this->seed->field_defs[strtolower($columnName)]['db_concat_fields'])) {
369                         foreach($this->seed->field_defs[strtolower($columnName)]['db_concat_fields'] as $index=>$field){
370                             if(!isset($this->filter_fields[strtolower($field)]) || !$this->filter_fields[strtolower($field)])
371                             {
372                                 $this->filter_fields[strtolower($field)] = true;
373                             }
374                         }
375                 }
376             }
377             foreach ($this->searchColumns as $columnName => $def )
378             {
379                 $this->filter_fields[strtolower($columnName)] = true;
380             }
381         }
382
383
384                 if (!empty($_REQUEST['query']) || (!empty($GLOBALS['sugar_config']['save_query']) && $GLOBALS['sugar_config']['save_query'] != 'populate_only')) {
385                         $data = $this->lvd->getListViewData($this->seed, $searchWhere, 0, -1, $this->filter_fields, $params, 'id');
386                 } else {
387                         $this->should_process = false;
388                         $data = array(
389                                 'data'=>array(),
390                             'pageData'=>array(
391                                 'bean'=>array('moduleDir'=>$this->seed->module_dir),
392                                         'ordering'=>'',
393                                         'offsets'=>array('total'=>0,'next'=>0,'current'=>0),
394                                 ),
395                         );
396                 }
397
398                 foreach($this->displayColumns as $columnName => $def)
399                 {
400                         $seedName =  strtolower($columnName);
401
402                         if(empty($this->displayColumns[$columnName]['type'])){
403                                 if(!empty($this->lvd->seed->field_defs[$seedName]['type'])){
404                                         $seedDef = $this->lvd->seed->field_defs[$seedName];
405                             $this->displayColumns[$columnName]['type'] = (!empty($seedDef['custom_type']))?$seedDef['custom_type']:$seedDef['type'];
406                         }else{
407                                 $this->displayColumns[$columnName]['type'] = '';
408                         }
409                         }//fi empty(...)
410
411                         if(!empty($this->lvd->seed->field_defs[$seedName]['options'])){
412                                         $this->displayColumns[$columnName]['options'] = $this->lvd->seed->field_defs[$seedName]['options'];
413                         }
414
415                 //C.L. Fix for 11177
416                 if($this->displayColumns[$columnName]['type'] == 'html') {
417                     $cField = $this->seed->custom_fields;
418                        if(isset($cField) && isset($cField->bean->$seedName)) {
419                                 $seedName2 = strtoupper($columnName);
420                                 $htmlDisplay = html_entity_decode($cField->bean->$seedName);
421                                 $count = 0;
422                                 while($count < count($data['data'])) {
423                                         $data['data'][$count][$seedName2] = &$htmlDisplay;
424                                     $count++;
425                                 }
426                         }
427                 }//fi == 'html'
428
429                         if (!empty($this->lvd->seed->field_defs[$seedName]['sort_on'])) {
430                         $this->displayColumns[$columnName]['orderBy'] = $this->lvd->seed->field_defs[$seedName]['sort_on'];
431                     }
432                 }
433
434                 $this->process($file, $data, $this->seed->object_name);
435         }
436
437         /*
438          * Return the where clause as per the REQUEST.
439          */
440         function _get_where_clause()
441         {
442                 $where = '';
443                 $where_clauses = $this->searchForm->generateSearchWhere(true, $this->seed->module_dir);
444
445                 // Bug 43452 - FG - Changed the way generated Where array is imploded into the string.
446                 //                  Now it's imploding in the same way view.list.php do.
447                 if (count($where_clauses) > 0 ) {
448                     $where = '( ' . implode(' and ', $where_clauses) . ' )';
449         }
450
451         // Need to include the default whereStatement
452                 if(!empty($this->_popupMeta['whereStatement'])){
453             if(!empty($where))$where .= ' AND ';
454             $where .= $this->_popupMeta['whereStatement'];
455                 }
456
457                 return $where;
458         }
459
460         /*
461          * Generate the data for the search form on the header of the Popup.
462          */
463                 function _build_field_defs(){
464                 $this->formData = array();
465                 $this->customFieldDefs = array();
466                 foreach($this->searchdefs[$this->module]['layout']['advanced_search'] as $data){
467                         if(is_array($data)){
468
469                                 $this->formData[] = array('field' => $data);
470                                 $value = '';
471                                 $this->customFieldDefs[$data['name']]= $data;
472                                 if(!empty($_REQUEST[$data['name']]))
473                         $value = $_REQUEST[$data['name']];
474                     $this->customFieldDefs[$data['name']]['value'] = $value;
475                         }else
476                                 $this->formData[] = array('field' => array('name'=>$data));
477                 }
478                 $this->fieldDefs = array();
479                 if($this->seed){
480                         $this->seed->fill_in_additional_detail_fields();
481
482                 foreach($this->seed->toArray() as $name => $value) {
483                     $this->fieldDefs[$name] = $this->seed->field_defs[$name];
484                     //if we have a relate type then reset to name so that we end up with a textbox
485                     //rather than a select button
486                     $this->fieldDefs[$name]['name'] = $this->fieldDefs[$name]['name'];
487                     if($this->fieldDefs[$name]['type'] == 'relate')
488                         $this->fieldDefs[$name]['type'] = 'name';
489                     if(isset($this->fieldDefs[$name]['options']) && isset($GLOBALS['app_list_strings'][$this->fieldDefs[$name]['options']])) {
490                         $this->fieldDefs[$name]['options'] = $GLOBALS['app_list_strings'][$this->fieldDefs[$name]['options']]; // fill in enums
491                     }
492                     if(!empty($_REQUEST[$name]))
493                         $value = $_REQUEST[$name];
494                     $this->fieldDefs[$name]['value'] = $value;
495                 }
496                 }
497         }
498
499         function _getAddForm(){
500                 $addform = '';
501         if(!$this->seed->ACLAccess('save')){
502             return;
503         }
504                 if(!empty($this->_popupMeta['create'])){
505                         $formBase = new $this->_popupMeta['create']['formBaseClass']();
506
507
508
509                                 // TODO: cleanup the construction of $addform
510                                 $prefix = empty($this->_popupMeta['create']['getFormBodyParams'][0]) ? '' : $this->_popupMeta['create']['getFormBodyParams'][0];
511                                 $mod = empty($this->_popupMeta['create']['getFormBodyParams'][1]) ? '' : $this->_popupMeta['create']['getFormBodyParams'][1];
512                                 $formBody = empty($this->_popupMeta['create']['getFormBodyParams'][2]) ? '' : $this->_popupMeta['create']['getFormBodyParams'][2];
513
514                                 $getFormMethod = (empty($this->_popupMeta['create']['getFormMethod']) ? 'getFormBody' : $this->_popupMeta['create']['getFormMethod']);
515                                 $formbody = $formBase->$getFormMethod($prefix, $mod, $formBody);
516
517                                 $addform = '<table><tr><td nowrap="nowrap" valign="top">'
518                                         . str_replace('<br>', '</td><td nowrap="nowrap" valign="top">&nbsp;', $formbody)
519                                         . '</td></tr></table>'
520                                         . '<input type="hidden" name="action" value="Popup" />';
521
522                         return $addform;
523                 }
524         }
525
526         function _getAddFormHeader(){
527                 $lbl_save_button_title = $GLOBALS['app_strings']['LBL_SAVE_BUTTON_TITLE'];
528                 $lbl_save_button_key = $GLOBALS['app_strings']['LBL_SAVE_BUTTON_KEY'];
529                 $lbl_save_button_label = $GLOBALS['app_strings']['LBL_SAVE_BUTTON_LABEL'];
530                 $module_dir = $this->seed->module_dir;
531 $formSave = <<<EOQ
532                         <input type="hidden" name="create" value="true">
533                         <input type="hidden" name="popup" value="true">
534                         <input type="hidden" name="to_pdf" value="true">
535                         <input type="hidden" name="return_module" value="$module_dir">
536                         <input type="hidden" name="return_action" value="Popup">
537 EOQ;
538                 // if metadata contains custom inputs for the quickcreate
539                 if(!empty($this->_popupMeta['customInput']) && is_array($this->_popupMeta['customInput'])) {
540                         foreach($this->_popupMeta['customInput'] as $key => $value)
541                                 $formSave .= '<input type="hidden" name="' . $key . '" value="'. $value .'">\n';
542                 }
543
544
545                 $addformheader = get_form_header($this->_popupMeta['create']['createButton'], $formSave, false);
546                 return $addformheader;
547         }
548
549         function getQuickCreate(){
550                 require_once("include/EditView/PopupQuickCreate.php");
551                 $qc = new PopupQuickCreate($this->module);
552                 return $qc->process($this->module);
553         }
554 }
555 ?>