| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363 |
- <?php
- /* Copyright (C) ---Put here your own copyright and developer email---
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
- /**
- * \file htdocs/modulebuilder/template/class/actions_mymodule.class.php
- * \ingroup mymodule
- * \brief Example hook overload.
- *
- * Put detailed description here.
- */
- /**
- * Class ActionsMyModule
- */
- class ActionsMyModule
- {
- /**
- * @var DoliDB Database handler.
- */
- public $db;
- /**
- * @var string Error code (or message)
- */
- public $error = '';
- /**
- * @var array Errors
- */
- public $errors = array();
- /**
- * @var array Hook results. Propagated to $hookmanager->resArray for later reuse
- */
- public $results = array();
- /**
- * @var string String displayed by executeHook() immediately after return
- */
- public $resprints;
- /**
- * @var int Priority of hook (50 is used if value is not defined)
- */
- public $priority;
- /**
- * Constructor
- *
- * @param DoliDB $db Database handler
- */
- public function __construct($db)
- {
- $this->db = $db;
- }
- /**
- * Execute action
- *
- * @param array $parameters Array of parameters
- * @param CommonObject $object The object to process (an invoice if you are in invoice module, a propale in propale's module, etc...)
- * @param string $action 'add', 'update', 'view'
- * @return int <0 if KO,
- * =0 if OK but we want to process standard actions too,
- * >0 if OK and we want to replace standard actions.
- */
- public function getNomUrl($parameters, &$object, &$action)
- {
- global $db, $langs, $conf, $user;
- $this->resprints = '';
- return 0;
- }
- /**
- * Overloading the doActions function : replacing the parent's function with the one below
- *
- * @param array $parameters Hook metadatas (context, etc...)
- * @param CommonObject $object The object to process (an invoice if you are in invoice module, a propale in propale's module, etc...)
- * @param string $action Current action (if set). Generally create or edit or null
- * @param HookManager $hookmanager Hook manager propagated to allow calling another hook
- * @return int < 0 on error, 0 on success, 1 to replace standard code
- */
- public function doActions($parameters, &$object, &$action, $hookmanager)
- {
- global $conf, $user, $langs;
- $error = 0; // Error counter
- /* print_r($parameters); print_r($object); echo "action: " . $action; */
- if (in_array($parameters['currentcontext'], array('somecontext1', 'somecontext2'))) { // do something only for the context 'somecontext1' or 'somecontext2'
- // Do what you want here...
- // You can for example call global vars like $fieldstosearchall to overwrite them, or update database depending on $action and $_POST values.
- }
- if (!$error) {
- $this->results = array('myreturn' => 999);
- $this->resprints = 'A text to show';
- return 0; // or return 1 to replace standard code
- } else {
- $this->errors[] = 'Error message';
- return -1;
- }
- }
- /**
- * Overloading the doMassActions function : replacing the parent's function with the one below
- *
- * @param array $parameters Hook metadatas (context, etc...)
- * @param CommonObject $object The object to process (an invoice if you are in invoice module, a propale in propale's module, etc...)
- * @param string $action Current action (if set). Generally create or edit or null
- * @param HookManager $hookmanager Hook manager propagated to allow calling another hook
- * @return int < 0 on error, 0 on success, 1 to replace standard code
- */
- public function doMassActions($parameters, &$object, &$action, $hookmanager)
- {
- global $conf, $user, $langs;
- $error = 0; // Error counter
- /* print_r($parameters); print_r($object); echo "action: " . $action; */
- if (in_array($parameters['currentcontext'], array('somecontext1', 'somecontext2'))) { // do something only for the context 'somecontext1' or 'somecontext2'
- foreach ($parameters['toselect'] as $objectid) {
- // Do action on each object id
- }
- }
- if (!$error) {
- $this->results = array('myreturn' => 999);
- $this->resprints = 'A text to show';
- return 0; // or return 1 to replace standard code
- } else {
- $this->errors[] = 'Error message';
- return -1;
- }
- }
- /**
- * Overloading the addMoreMassActions function : replacing the parent's function with the one below
- *
- * @param array $parameters Hook metadatas (context, etc...)
- * @param CommonObject $object The object to process (an invoice if you are in invoice module, a propale in propale's module, etc...)
- * @param string $action Current action (if set). Generally create or edit or null
- * @param HookManager $hookmanager Hook manager propagated to allow calling another hook
- * @return int < 0 on error, 0 on success, 1 to replace standard code
- */
- public function addMoreMassActions($parameters, &$object, &$action, $hookmanager)
- {
- global $conf, $user, $langs;
- $error = 0; // Error counter
- $disabled = 1;
- /* print_r($parameters); print_r($object); echo "action: " . $action; */
- if (in_array($parameters['currentcontext'], array('somecontext1', 'somecontext2'))) { // do something only for the context 'somecontext1' or 'somecontext2'
- $this->resprints = '<option value="0"'.($disabled ? ' disabled="disabled"' : '').'>'.$langs->trans("MyModuleMassAction").'</option>';
- }
- if (!$error) {
- return 0; // or return 1 to replace standard code
- } else {
- $this->errors[] = 'Error message';
- return -1;
- }
- }
- /**
- * Execute action
- *
- * @param array $parameters Array of parameters
- * @param Object $object Object output on PDF
- * @param string $action 'add', 'update', 'view'
- * @return int <0 if KO,
- * =0 if OK but we want to process standard actions too,
- * >0 if OK and we want to replace standard actions.
- */
- public function beforePDFCreation($parameters, &$object, &$action)
- {
- global $conf, $user, $langs;
- global $hookmanager;
- $outputlangs = $langs;
- $ret = 0; $deltemp = array();
- dol_syslog(get_class($this).'::executeHooks action='.$action);
- /* print_r($parameters); print_r($object); echo "action: " . $action; */
- if (in_array($parameters['currentcontext'], array('somecontext1', 'somecontext2'))) { // do something only for the context 'somecontext1' or 'somecontext2'
- }
- return $ret;
- }
- /**
- * Execute action
- *
- * @param array $parameters Array of parameters
- * @param Object $pdfhandler PDF builder handler
- * @param string $action 'add', 'update', 'view'
- * @return int <0 if KO,
- * =0 if OK but we want to process standard actions too,
- * >0 if OK and we want to replace standard actions.
- */
- public function afterPDFCreation($parameters, &$pdfhandler, &$action)
- {
- global $conf, $user, $langs;
- global $hookmanager;
- $outputlangs = $langs;
- $ret = 0; $deltemp = array();
- dol_syslog(get_class($this).'::executeHooks action='.$action);
- /* print_r($parameters); print_r($object); echo "action: " . $action; */
- if (in_array($parameters['currentcontext'], array('somecontext1', 'somecontext2'))) {
- // do something only for the context 'somecontext1' or 'somecontext2'
- }
- return $ret;
- }
- /**
- * Overloading the loadDataForCustomReports function : returns data to complete the customreport tool
- *
- * @param array $parameters Hook metadatas (context, etc...)
- * @param string $action Current action (if set). Generally create or edit or null
- * @param HookManager $hookmanager Hook manager propagated to allow calling another hook
- * @return int < 0 on error, 0 on success, 1 to replace standard code
- */
- public function loadDataForCustomReports($parameters, &$action, $hookmanager)
- {
- global $conf, $user, $langs;
- $langs->load("mymodule@mymodule");
- $this->results = array();
- $head = array();
- $h = 0;
- if ($parameters['tabfamily'] == 'mymodule') {
- $head[$h][0] = dol_buildpath('/module/index.php', 1);
- $head[$h][1] = $langs->trans("Home");
- $head[$h][2] = 'home';
- $h++;
- $this->results['title'] = $langs->trans("MyModule");
- $this->results['picto'] = 'mymodule@mymodule';
- }
- $head[$h][0] = 'customreports.php?objecttype='.$parameters['objecttype'].(empty($parameters['tabfamily']) ? '' : '&tabfamily='.$parameters['tabfamily']);
- $head[$h][1] = $langs->trans("CustomReports");
- $head[$h][2] = 'customreports';
- $this->results['head'] = $head;
- return 1;
- }
- /**
- * Overloading the restrictedArea function : check permission on an object
- *
- * @param array $parameters Hook metadatas (context, etc...)
- * @param string $action Current action (if set). Generally create or edit or null
- * @param HookManager $hookmanager Hook manager propagated to allow calling another hook
- * @return int <0 if KO,
- * =0 if OK but we want to process standard actions too,
- * >0 if OK and we want to replace standard actions.
- */
- public function restrictedArea($parameters, &$action, $hookmanager)
- {
- global $user;
- if ($parameters['features'] == 'myobject') {
- if ($user->rights->mymodule->myobject->read) {
- $this->results['result'] = 1;
- return 1;
- } else {
- $this->results['result'] = 0;
- return 1;
- }
- }
- return 0;
- }
- /**
- * Execute action completeTabsHead
- *
- * @param array $parameters Array of parameters
- * @param CommonObject $object The object to process (an invoice if you are in invoice module, a propale in propale's module, etc...)
- * @param string $action 'add', 'update', 'view'
- * @param Hookmanager $hookmanager hookmanager
- * @return int <0 if KO,
- * =0 if OK but we want to process standard actions too,
- * >0 if OK and we want to replace standard actions.
- */
- public function completeTabsHead(&$parameters, &$object, &$action, $hookmanager)
- {
- global $langs, $conf, $user;
- if (!isset($parameters['object']->element)) {
- return 0;
- }
- if ($parameters['mode'] == 'remove') {
- // utilisé si on veut faire disparaitre des onglets.
- return 0;
- } elseif ($parameters['mode'] == 'add') {
- $langs->load('mymodule@mymodule');
- // utilisé si on veut ajouter des onglets.
- $counter = count($parameters['head']);
- $element = $parameters['object']->element;
- $id = $parameters['object']->id;
- // verifier le type d'onglet comme member_stats où ça ne doit pas apparaitre
- // if (in_array($element, ['societe', 'member', 'contrat', 'fichinter', 'project', 'propal', 'commande', 'facture', 'order_supplier', 'invoice_supplier'])) {
- if (in_array($element, ['context1', 'context2'])) {
- $datacount = 0;
- $parameters['head'][$counter][0] = dol_buildpath('/mymodule/mymodule_tab.php', 1) . '?id=' . $id . '&module='.$element;
- $parameters['head'][$counter][1] = $langs->trans('MyModuleTab');
- if ($datacount > 0) {
- $parameters['head'][$counter][1] .= '<span class="badge marginleftonlyshort">' . $datacount . '</span>';
- }
- $parameters['head'][$counter][2] = 'mymoduleemails';
- $counter++;
- }
- if ($counter > 0 && (int) DOL_VERSION < 14) {
- $this->results = $parameters['head'];
- // return 1 to replace standard code
- return 1;
- } else {
- // en V14 et + $parameters['head'] est modifiable par référence
- return 0;
- }
- }
- }
- /* Add here any other hooked methods... */
- }
|