2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
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.
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
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
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.
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.
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 ********************************************************************************/
38 $dictionary['Meeting'] = array('table' => 'meetings',
39 'unified_search' => true,
40 'comment' => 'Meeting activities'
45 'vname' => 'LBL_SUBJECT',
48 'dbType' => 'varchar',
49 'unified_search' => true,
51 'comment' => 'Meeting name',
52 'importable' => 'required',
54 'accept_status' => array (
55 'name' => 'accept_status',
56 'vname' => 'LBL_SUBJECT',
58 'dbType' => 'varchar',
63 'set_accept_links' => array (
64 'name' => 'accept_status',
65 'vname' => 'LBL_SUBJECT',
67 'dbType' => 'varchar',
74 'vname' => 'LBL_LOCATION',
77 'comment' => 'Meeting location'
81 'name' => 'duration_hours',
82 'vname' => 'LBL_DURATION_HOURS',
85 'comment' => 'Duration (hours)',
86 'importable' => 'required',
91 'name' => 'duration_minutes',
92 'vname' => 'LBL_DURATION_MINUTES',
94 'group'=>'duration_hours',
95 'function' => array('name'=>'getDurationMinutesOptions', 'returns'=>'html', 'include'=>'modules/Calls/CallHelper.php'),
97 'comment' => 'Duration (minutes)'
101 'name' => 'date_start',
102 'vname' => 'LBL_DATE',
103 'type' => 'datetimecombo',
104 'dbType' => 'datetime',
105 'comment' => 'Date of start of meeting',
106 'importable' => 'required',
112 'name' => 'date_end',
113 'vname' => 'LBL_DATE_END',
116 'comment' => 'Date meeting ends'
120 'name' => 'parent_type',
121 'vname'=>'LBL_LIST_RELATED_TO',
122 'type' =>'parent_type',
123 'dbType' => 'varchar',
124 'group'=>'parent_name',
126 'comment' => 'Module meeting is associated with'
131 'vname' => 'LBL_STATUS',
134 'options' => 'meeting_status_dom',
135 'comment' => 'Meeting status (ex: Planned, Held, Not held)'
137 // Bug 24170 - Added only to allow the sidequickcreate form to work correctly
140 'name' => 'direction',
141 'vname' => 'LBL_DIRECTION',
144 'options' => 'call_direction_dom',
145 'comment' => 'Indicates whether call is inbound or outbound',
146 'source' => 'non-db',
147 'importable' => 'false',
154 'name' => 'parent_id',
155 'vname'=>'LBL_LIST_RELATED_TO',
157 'group'=>'parent_name',
159 'comment' => 'ID of item indicated by parent_type'
161 'reminder_checked'=>array(
162 'name' => 'reminder_checked',
163 'vname' => 'LBL_REMINDER',
165 'source' => 'non-db',
166 'comment' => 'checkbox indicating whether or not the reminder value is set (Meta-data only)',
172 'name' => 'reminder_time',
173 'vname' => 'LBL_REMINDER_TIME',
175 'function' => array('name'=>'getReminderTime', 'returns'=>'html', 'include'=>'modules/Calls/CallHelper.php', 'onListView'=>true ),
176 'reportable' => false,
178 'comment' => 'Specifies when a reminder alert should be issued; -1 means no alert; otherwise the number of seconds prior to the start'
182 'name' => 'outlook_id',
183 'vname' => 'LBL_OUTLOOK_ID',
186 'reportable' => false,
187 'comment' => 'When the Sugar Plug-in for Microsoft Outlook syncs an Outlook appointment, this is the Outlook appointment item ID'
192 'name' => 'contact_name',
193 'rname' => 'last_name',
194 'db_concat_fields'=> array(0=>'first_name', 1=>'last_name'),
195 'id_name' => 'contact_id',
196 'massupdate' => false,
197 'vname' => 'LBL_CONTACT_NAME',
200 'table' => 'contacts',
202 'module' => 'Contacts',
203 'join_name' => 'contacts',
204 'dbType' => 'varchar',
212 'name' => 'contacts',
214 'relationship' => 'meetings_contacts',
216 'vname'=>'LBL_CONTACTS',
220 'name'=> 'parent_name',
221 'parent_type'=>'record_type_display' ,
222 'type_name'=>'parent_type',
223 'id_name'=>'parent_id',
224 'vname'=>'LBL_LIST_RELATED_TO',
226 'group'=>'parent_name',
228 'options'=> 'parent_type_display',
234 'relationship' => 'meetings_users',
236 'vname'=>'LBL_USERS',
240 'name' => 'accounts',
242 'relationship' => 'account_meetings',
244 'vname'=>'LBL_ACCOUNT',
250 'relationship' => 'meetings_leads',
252 'vname'=>'LBL_LEADS',
256 'name' => 'opportunity',
258 'relationship' => 'opportunity_meetings',
260 'vname'=>'LBL_OPPORTUNITY',
266 'relationship' => 'case_meetings',
274 'relationship' => 'meetings_notes',
278 'vname'=>'LBL_NOTES',
280 'contact_id' => array(
281 'name' => 'contact_id',
283 'source' => 'non-db',
286 'relationships' => array (
287 'meetings_assigned_user' =>
288 array('lhs_module'=> 'Users', 'lhs_table'=> 'users', 'lhs_key' => 'id',
289 'rhs_module'=> 'Meetings', 'rhs_table'=> 'meetings', 'rhs_key' => 'assigned_user_id',
290 'relationship_type'=>'one-to-many')
292 ,'meetings_modified_user' =>
293 array('lhs_module'=> 'Users', 'lhs_table'=> 'users', 'lhs_key' => 'id',
294 'rhs_module'=> 'Meetings', 'rhs_table'=> 'meetings', 'rhs_key' => 'modified_user_id',
295 'relationship_type'=>'one-to-many')
297 ,'meetings_created_by' =>
298 array('lhs_module'=> 'Users', 'lhs_table'=> 'users', 'lhs_key' => 'id',
299 'rhs_module'=> 'Meetings', 'rhs_table'=> 'meetings', 'rhs_key' => 'created_by',
300 'relationship_type'=>'one-to-many')
302 ,'meetings_notes' => array('lhs_module'=> 'Meetings', 'lhs_table'=> 'meetings', 'lhs_key' => 'id',
303 'rhs_module'=> 'Notes', 'rhs_table'=> 'notes', 'rhs_key' => 'parent_id',
304 'relationship_type'=>'one-to-many', 'relationship_role_column'=>'parent_type',
305 'relationship_role_column_value'=>'Meetings')
308 , 'indices' => array (
309 array('name' =>'idx_mtg_name', 'type'=>'index', 'fields'=>array('name')),
310 array('name' =>'idx_meet_par_del', 'type'=>'index', 'fields'=>array('parent_id','parent_type','deleted')),
311 array('name' => 'idx_meet_stat_del', 'type' => 'index', 'fields'=> array('assigned_user_id', 'status', 'deleted')),
314 //This enables optimistic locking for Saves From EditView
315 ,'optimistic_locking'=>true,
318 VardefManager::createVardef('Meetings','Meeting', array('default', 'assignable',