// Key text used to identify module (for permissions, menus, etc...)
$this->rights_class='partnership';
// Family can be 'base' (core modules),'crm','financial','hr','projects','products','ecm','technic' (transverse modules),'interface' (link with external tools),'other','...'
// It is used to group modules by family in module setup page
$this->family="crm";
// Module position in the family on 2 digits ('01', '10', '20', ...)
$this->module_position='90';
// Gives the possibility for the module, to provide his own family info and position of this family (Overwrite $this->family and $this->module_position. Avoid this)
// Define some features supported by module (triggers, login, substitutions, menus, css, etc...)
$this->module_parts=array(
// Set this to 1 if module has its own trigger directory (core/triggers)
'triggers'=>0,
// Set this to 1 if module has its own login method file (core/login)
'login'=>0,
// Set this to 1 if module has its own substitution function file (core/substitutions)
'substitutions'=>0,
// Set this to 1 if module has its own menus handler directory (core/menus)
'menus'=>0,
// Set this to 1 if module overwrite template dir (core/tpl)
'tpl'=>0,
// Set this to 1 if module has its own barcode directory (core/modules/barcode)
'barcode'=>0,
// Set this to 1 if module has its own models directory (core/modules/xxx)
'models'=>1,
// Set this to 1 if module has its own printing directory (core/modules/printing)
'printing'=>0,
// Set this to 1 if module has its own theme directory (theme)
'theme'=>0,
// Set this to relative path of css file if module has its own css file
'css'=>array(
// '/partnership/css/partnership.css.php',
),
// Set this to relative path of js file if module must load a js on all pages
'js'=>array(
// '/partnership/js/partnership.js.php',
),
// Set here all hooks context managed by module. To find available hook context, make a "grep -r '>initHooks(' *" on source code. You can also set hook context to 'all'
'hooks'=>array(
// 'data' => array(
// 'hookcontext1',
// 'hookcontext2',
// ),
// 'entity' => '0',
),
// Set this to 1 if features of module are opened to external users
'moduleforexternal'=>0,
);
// Data directories to create when module is enabled.
// List of module class names as string that must be enabled if this module is enabled. Example: array('always1'=>'modModuleToEnable1','always2'=>'modModuleToEnable2', 'FR1'=>'modModuleToEnableFR'...)
$this->depends=array();
$this->requiredby=array();// List of module class names as string to disable if this one is disabled. Example: array('modModuleToDisable1', ...)
$this->conflictwith=array();// List of module class names as string this module is in conflict with. Example: array('modModuleToDisable1', ...)
$this->need_dolibarr_version=array(11,-3);// Minimum version of Dolibarr required by module
// Messages at activation
$this->warnings_activation=array();// Warning to show when we activate module. array('always'='text') or array('FR'='textfr','ES'='textes'...)
$this->warnings_activation_ext=array();// Warning to show when we activate an external module. array('always'='text') or array('FR'='textfr','ES'='textes'...)
// $this->tabs[] = array('data'=>'objecttype:+tabname1:Title1:mylangfile@partnership:$user->rights->partnership->read:/partnership/mynewtab1.php?id=__ID__'); // To add a new tab identified by code tabname1
// $this->tabs[] = array('data'=>'objecttype:+tabname2:SUBSTITUTION_Title2:mylangfile@partnership:$user->rights->othermodule->read:/partnership/mynewtab2.php?id=__ID__', // To add another new tab identified by code tabname2. Label will be result of calling all substitution functions on 'Title2' key.
// $this->tabs[] = array('data'=>'objecttype:-tabname:NU:conditiontoremove'); // To remove an existing tab identified by code tabname
//
// Where objecttype can be
// 'categories_x' to add a tab in category view (replace 'x' by type of category (0=product, 1=supplier, 2=customer, 3=member)
// 'contact' to add a tab in contact view
// 'contract' to add a tab in contract view
// 'group' to add a tab in group view
// 'intervention' to add a tab in intervention view
// 'invoice' to add a tab in customer invoice view
// 'invoice_supplier' to add a tab in supplier invoice view
// 'member' to add a tab in fundation member view
// 'opensurveypoll' to add a tab in opensurvey poll view
'tabsql'=>array('SELECT f.rowid as rowid, f.code, f.label, f.keyword, f.active FROM '.MAIN_DB_PREFIX.'c_partnership_type as f WHERE f.entity = '.((int)$conf->entity)),
0=>array('priority'=>60,'label'=>'CancelPartnershipForExpiredMembers','jobtype'=>'method','class'=>'/partnership/class/partnershiputils.class.php','objectname'=>'PartnershipUtils','method'=>'doCancelStatusOfMemberPartnership','parameters'=>'','comment'=>'Cancel status of partnership when subscription is expired + x days.','frequency'=>1,'unitfrequency'=>86400,'status'=>1,'test'=>'$conf->partnership->enabled','datestart'=>$datestart),
1=>array('priority'=>61,'label'=>'PartnershipCheckBacklink','jobtype'=>'method','class'=>'/partnership/class/partnershiputils.class.php','objectname'=>'PartnershipUtils','method'=>'doWarningOfPartnershipIfDolibarrBacklinkNotfound','parameters'=>'','comment'=>'Warning of partnership if Dolibarr backlink not found on partner website.','frequency'=>1,'unitfrequency'=>86400,'status'=>0,'test'=>'$conf->partnership->enabled','datestart'=>$datestart),
// // '' if this is a top menu. For left menu, use 'fk_mainmenu=xxx' or 'fk_mainmenu=xxx,fk_leftmenu=yyy' where xxx is mainmenucode and yyy is a leftmenucode
// 'fk_menu'=>'fk_mainmenu=partnership',
// // This is a Left menu entry
// 'type'=>'left',
// 'titre'=>'List Partnership',
// 'mainmenu'=>'partnership',
// 'leftmenu'=>'partnership',
// 'url'=>'/partnership/partnership_list.php',
// // Lang file to use (without .lang) by module. File must be in langs/code_CODE/ directory.
// // Define condition to show or hide menu entry. Use '$conf->partnership->enabled' if entry must be visible if module is enabled. Use '$leftmenu==\'system\'' to show if leftmenu system is selected.
// 'enabled'=>'$conf->partnership->enabled',
// // Use 'perms'=>'$user->rights->partnership->level1->level2' if you want your menu with a permission rules
// 'perms'=>'1',
// 'target'=>'',
// // 0=Menu for internal users, 1=external users, 2=both
'fk_menu'=>'fk_mainmenu='.$fk_mainmenu,// '' if this is a top menu. For left menu, use 'fk_mainmenu=xxx' or 'fk_mainmenu=xxx,fk_leftmenu=yyy' where xxx is mainmenucode and yyy is a leftmenucode
'langs'=>'partnership',// Lang file to use (without .lang) by module. File must be in langs/code_CODE/ directory.
'position'=>1100+$r,
'enabled'=>'$conf->partnership->enabled',// Define condition to show or hide menu entry. Use '$conf->partnership->enabled' if entry must be visible if module is enabled.
'fk_menu'=>'fk_mainmenu='.$fk_mainmenu.',fk_leftmenu=partnership',// '' if this is a top menu. For left menu, use 'fk_mainmenu=xxx' or 'fk_mainmenu=xxx,fk_leftmenu=yyy' where xxx is mainmenucode and yyy is a leftmenucode
'langs'=>'partnership',// Lang file to use (without .lang) by module. File must be in langs/code_CODE/ directory.
'position'=>1100+$r,
'enabled'=>'$conf->partnership->enabled',// Define condition to show or hide menu entry. Use '$conf->partnership->enabled' if entry must be visible if module is enabled. Use '$leftmenu==\'system\'' to show if leftmenu system is selected.
'perms'=>'$user->rights->partnership->write',// Use 'perms'=>'$user->rights->partnership->level1->level2' if you want your menu with a permission rules
'fk_menu'=>'fk_mainmenu='.$fk_mainmenu.',fk_leftmenu=partnership',// '' if this is a top menu. For left menu, use 'fk_mainmenu=xxx' or 'fk_mainmenu=xxx,fk_leftmenu=yyy' where xxx is mainmenucode and yyy is a leftmenucode
'langs'=>'partnership',// Lang file to use (without .lang) by module. File must be in langs/code_CODE/ directory.
'position'=>1100+$r,
'enabled'=>'$conf->partnership->enabled',// Define condition to show or hide menu entry. Use '$conf->partnership->enabled' if entry must be visible if module is enabled. Use '$leftmenu==\'system\'' to show if leftmenu system is selected.
//$this->export_dependencies_array[$r] = array('partnershipline'=>array('tl.rowid','tl.ref')); // To force to activate one or several fields if we select some fields that need same (like to select a unique key if we ask a field of a child to avoid the DISTINCT to discard them, or for computed field than need several other fields)
//$this->export_dependencies_array[$r]=array('mysubobject'=>'ts.rowid', 't.myfield'=>array('t.myfield2','t.myfield3')); // To force to activate one or several fields if we select some fields that need same (like to select a unique key if we ask a field of a child to avoid the DISTINCT to discard them, or for computed field than need several other fields)
$this->export_sql_start[$r]='SELECT DISTINCT ';
$this->export_sql_end[$r]=' FROM '.MAIN_DB_PREFIX.'partnership as t';
$this->export_sql_end[$r].=' WHERE 1 = 1';
$this->export_sql_end[$r].=' AND t.entity IN ('.getEntity('partnership').')';
return-1;// Do not activate module if error 'not allowed' returned when loading module SQL queries (the _load_table run sql with run_sql with the error allowed parameter set to 'default')
"DELETE FROM ".MAIN_DB_PREFIX."document_model WHERE nom = 'standard_".strtolower($myTmpObjectKey)."' AND type = '".strtolower($myTmpObjectKey)."' AND entity = ".((int)$conf->entity),
"INSERT INTO ".MAIN_DB_PREFIX."document_model (nom, type, entity) VALUES('standard_".strtolower($myTmpObjectKey)."','".strtolower($myTmpObjectKey)."',".((int)$conf->entity).")",
"DELETE FROM ".MAIN_DB_PREFIX."document_model WHERE nom = 'generic_".strtolower($myTmpObjectKey)."_odt' AND type = '".strtolower($myTmpObjectKey)."' AND entity = ".((int)$conf->entity),
"INSERT INTO ".MAIN_DB_PREFIX."document_model (nom, type, entity) VALUES('generic_".strtolower($myTmpObjectKey)."_odt', '".strtolower($myTmpObjectKey)."', ".((int)$conf->entity).")"