All Data Structures Functions Variables Pages
StateMetadataAdapter.php
1 <?php
2  /*********************************************************************************
3  * Zurmo is a customer relationship management program developed by
4  * Zurmo, Inc. Copyright (C) 2017 Zurmo Inc.
5  *
6  * Zurmo is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License version 3 as published by the
8  * Free Software Foundation with the addition of the following permission added
9  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10  * IN WHICH THE COPYRIGHT IS OWNED BY ZURMO, ZURMO DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  *
13  * Zurmo is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Affero General Public License along with
19  * this program; if not, see http://www.gnu.org/licenses or write to the Free
20  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  * 02110-1301 USA.
22  *
23  * You can contact Zurmo, Inc. with a mailing address at 27 North Wacker Drive
24  * Suite 370 Chicago, IL 60606. or at email address contact@zurmo.com.
25  *
26  * The interactive user interfaces in original and modified versions
27  * of this program must display Appropriate Legal Notices, as required under
28  * Section 5 of the GNU Affero General Public License version 3.
29  *
30  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31  * these Appropriate Legal Notices must retain the display of the Zurmo
32  * logo and Zurmo copyright notice. If the display of the logo is not reasonably
33  * feasible for technical reasons, the Appropriate Legal Notices must display the words
34  * "Copyright Zurmo Inc. 2017. All rights reserved".
35  ********************************************************************************/
36 
42  {
43  protected $metadata;
44 
45  public static function getStateAttributeName()
46  {
47  throw new NotImplementedException();
48  }
49 
50  public function __construct(array $metadata)
51  {
52  assert('isset($metadata["clauses"])');
53  assert('isset($metadata["structure"])');
54  $this->metadata = $metadata;
55  }
56 
62  {
63  $metadata = $this->metadata;
64  $stateIds = $this->getStateIds();
65  $clauseCount = count($metadata['clauses']);
66  $startingCount = $clauseCount + 1;
67  $structure = '';
68  $first = true;
69  //No StateIds mean the list should come up empty
70  if (count($stateIds) == 0)
71  {
72  $metadata['clauses'][$startingCount] = array(
73  'attributeName' => 'state',
74  'operatorType' => 'equals',
75  'value' => -1
76  );
77  $structure .= $startingCount;
78  $startingCount++;
79  }
80  else
81  {
82  foreach ($stateIds as $stateId)
83  {
84  $metadata['clauses'][$startingCount] = array(
85  'attributeName' => 'state',
86  'operatorType' => 'equals',
87  'value' => $stateId
88  );
89  if (!$first)
90  {
91  $structure .= ' or ';
92  }
93  $first = false;
94  $structure .= $startingCount;
95  $startingCount++;
96  }
97  }
98  if (empty($metadata['structure']))
99  {
100  $metadata['structure'] = '(' . $structure . ')';
101  }
102  else
103  {
104  $metadata['structure'] = '(' . $metadata['structure'] . ') and (' . $structure . ')';
105  }
106  return $metadata;
107  }
108 
113  abstract protected function getStateIds();
114 
119  public static function getStateModelClassName()
120  {
121  throw new NotImplementedException();
122  }
123 
129  public static function getModuleClassNameByModel(RedBeanModel $model)
130  {
131  return $model::getModuleClassName();
132  }
133 
134  public static function resolveModuleClassNameByModel(RedBeanModel $model)
135 
136  {
137  $moduleClassName = $model::getModuleClassName();
138  $stateMetadataAdapterClassName = $moduleClassName::getStateMetadataAdapterClassName();
139  if ($stateMetadataAdapterClassName != null)
140  {
141  $moduleClassName = $stateMetadataAdapterClassName::getModuleClassNameByModel($model);
142  }
143  return $moduleClassName;
144  }
145  }
146 ?>
static getModuleClassNameByModel(RedBeanModel $model)
Generated on Tue May 26 2020 07:10:25