3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2014
37 * This class generates form element for free tag widget
40 class CRM_Core_Form_Tag
{
41 public $_entityTagValues;
44 * build tag widget if correct parent is passed
46 * @param CRM_Core_Form $form form object
47 * @param string $parentNames parent name ( tag name)
48 * @param string $entityTable entitytable 'eg: civicrm_contact'
49 * @param int $entityId entityid 'eg: contact id'
50 * @param boolean $skipTagCreate true if tag need be created using ajax
51 * @param boolean $skipEntityAction true if need to add entry in entry table via ajax
52 * @param string $tagsetElementName if you need to create tagsetlist with specific name
58 static function buildQuickForm(&$form, $parentNames, $entityTable, $entityId = NULL, $skipTagCreate = FALSE,
59 $skipEntityAction = FALSE, $tagsetElementName = NULL ) {
60 $tagset = $form->_entityTagValues
= array();
61 $form->assign("isTagset", FALSE);
64 foreach ($parentNames as &$parentNameItem) {
65 // get the parent id for tag list input for keyword
66 $parentId = CRM_Core_DAO
::getFieldValue('CRM_Core_DAO_Tag', $parentNameItem, 'id', 'name');
68 // check if parent exists
70 $tagsetItem = $tagsetElementName . 'parentId_' . $parentId;
71 $tagset[$tagsetItem]['parentID'] = $parentId;
73 list(, $mode) = explode('_', $entityTable);
74 if (!$tagsetElementName) {
75 $tagsetElementName = $mode . "_taglist";
77 $tagset[$tagsetItem]['tagsetElementName'] = $tagsetElementName;
79 $form->addEntityRef("{$tagsetElementName}[{$parentId}]", $parentNameItem, array(
82 'create' => !$skipTagCreate,
83 'api' => array('params' => array('parent_id' => $parentId)),
84 'data-entity_table' => $entityTable,
85 'data-entity_id' => $entityId,
86 'class' => "crm-$mode-tagset",
90 $tagset[$tagsetItem]['entityId'] = $entityId;
91 $entityTags = CRM_Core_BAO_EntityTag
::getChildEntityTags($parentId, $entityId, $entityTable);
93 $form->setDefaults(array("{$tagsetElementName}[{$parentId}]" => implode(',', array_keys($entityTags))));
97 $skipEntityAction = TRUE;
99 $tagset[$tagsetItem]['skipEntityAction'] = $skipEntityAction;
103 if (!empty($tagset)) {
104 // assign current tagsets which is used in postProcess
105 $form->_tagsetInfo
= $tagset;
106 $form->assign("tagsetType", $mode);
107 // Merge this tagset info with possibly existing info in the template
108 $tagsetInfo = (array) $form->get_template_vars("tagsetInfo");
109 if (empty($tagsetInfo[$mode])) {
110 $tagsetInfo[$mode] = array();
112 $tagsetInfo[$mode] = array_merge($tagsetInfo[$mode], $tagset);
113 $form->assign("tagsetInfo", $tagsetInfo);
114 $form->assign("isTagset", TRUE);
119 * save entity tags when it is not save used AJAX
121 * @param array $params associated array
122 * @param int $entityId entity id, eg: contact id, activity id, case id, file id
123 * @param string $entityTable entity table
124 * @param CRM_Core_Form $form form object
130 static function postProcess(&$params, $entityId, $entityTable = 'civicrm_contact', &$form) {
131 if ($form && !empty($form->_entityTagValues
)) {
132 $existingTags = $form->_entityTagValues
;
135 $existingTags = CRM_Core_BAO_EntityTag
::getTag($entityId, $entityTable);
139 // if the key is missing from the form response then all the tags were deleted / cleared
140 // in that case we create empty tagset params so that below logic works and tagset are
142 foreach ($form->_tagsetInfo
as $tagsetName => $tagsetInfo) {
143 $tagsetId = explode('parentId_', $tagsetName);
144 $tagsetId = $tagsetId[1];
145 if (empty($params[$tagsetId])) {
146 $params[$tagsetId] = '';
151 // when form is submitted with tagset values below logic will work and in the case when all tags in a tagset
152 // are deleted we will have to set $params[tagset id] = '' which is done by above logic
153 foreach ($params as $parentId => $value) {
154 $newTagIds = array();
158 $tagIds = explode(',', $value);
159 foreach ($tagIds as $tagId) {
160 if ($form && $form->_action
!= CRM_Core_Action
::UPDATE ||
!array_key_exists($tagId, $existingTags)) {
161 $newTagIds[] = $tagId;
166 // Any existing entity tags from this tagset missing from the $params should be deleted
167 $deleteSQL = "DELETE FROM civicrm_entity_tag
168 USING civicrm_entity_tag, civicrm_tag
169 WHERE civicrm_tag.id=civicrm_entity_tag.tag_id
170 AND civicrm_entity_tag.entity_table='{$entityTable}'
171 AND entity_id={$entityId} AND parent_id={$parentId}";
172 if (!empty($tagIds)) {
173 $deleteSQL .= " AND tag_id NOT IN (" . implode(', ', $tagIds) . ");";
176 CRM_Core_DAO
::executeQuery($deleteSQL);
178 if (!empty($newTagIds)) {
179 // New tag ids can be inserted directly into the db table.
180 $insertValues = array();
181 foreach ($newTagIds as $tagId) {
182 $insertValues[] = "( {$tagId}, {$entityId}, '{$entityTable}' ) ";
184 $insertSQL = 'INSERT INTO civicrm_entity_tag ( tag_id, entity_id, entity_table )
185 VALUES ' . implode(', ', $insertValues) . ';';
186 CRM_Core_DAO
::executeQuery($insertSQL);