source: trunk/workflow/inc/class.bo_move_instances.inc.php @ 795

Revision 795, 2.9 KB checked in by viani, 15 years ago (diff)

Ticket #488 - Inclusão do módulo workflow no ramo trunk do repositório Expresso.

Line 
1<?php
2
3/**************************************************************************\
4* eGroupWare                                                               *
5* http://www.egroupware.org                                                *
6* --------------------------------------------                             *
7*  This program is free software; you can redistribute it and/or modify it *
8*  under the terms of the GNU General Public License as published by the   *
9*  Free Software Foundation; either version 2 of the License, or (at your  *
10*  option) any later version.                                              *
11\**************************************************************************/
12
13require_once('class.bo_ajaxinterface.inc.php');
14require_once('class.so_move_instances.inc.php');
15require_once('nano/JSON.php');
16
17
18/**
19 * Camada Business para Mover Instâncias.
20 * @package Workflow
21 * @author Sidnei Augusto Drovetto Jr. - drovetto@gmail.com
22 * @license http://www.gnu.org/copyleft/gpl.html GPL
23 */
24class bo_move_instances extends bo_ajaxinterface
25{
26        /**
27         * @var object $so Acesso à camada model.
28         * @access private
29         */
30        private $so;
31
32
33        /**
34         * Construtor da classe bo_move_instances
35         * @return object
36         * @access public
37         */
38        function bo_move_instances()
39        {
40                parent::bo_ajaxinterface();
41                $this->so = new so_move_instances();
42        }
43
44        /**
45         * Carrega a lista de todos os processos que o usuário tem direito.
46         * @return array Lista dos processos.
47         * @access public
48         */
49        function loadProcesses()
50        {
51                $output = $this->so->loadProcesses();
52                $this->disconnect_all();
53
54                return $output;
55        }
56
57        /**
58         * Carrega a lista de todos as atividades dos processos que terão as instâncias movidas.
59         * @param array $params Uma array contendo os parâmetros necessários para buscar as atividades dos processos.
60         * @return array Lista das atividades de cada processo e um pré-relacionamento das atividades.
61         * @access public
62         */
63        function loadActivities($params)
64        {
65                $output['from'] = $this->so->loadProcessActivities($params['from']);
66                $output['to'] = $this->so->loadProcessActivities($params['to']);
67                $output['pre-match'] = $this->so->matchActivities($output['from'], $output['to'], 80);
68                $this->disconnect_all();
69
70                return $output;
71        }
72
73        /**
74         * Move as instâncias de um processo para outro.
75         * @param array $params Uma array contendo os parâmetros necessários para mover as instâncias.
76         * @return bool TRUE em caso de sucesso e FALSE caso contrário.
77         * @access public
78         */
79        function moveInstances($params)
80        {
81                $JSON = new Services_JSON();
82
83                /* convert the mappgin element to array */
84                $params['activityMappings'] = array_map("get_object_vars", get_object_vars($JSON->decode($params['activityMappings'])));
85
86                $active = ($params['active'] == 'on');
87                $completed = ($params['completed'] == 'on');
88
89                return $this->so->moveInstances($params['from'], $params['to'], $params['activityMappings'], $active, $completed);
90        }
91}
92?>
Note: See TracBrowser for help on using the repository browser.