X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=CRM%2FAdmin%2FForm%2FTag.php;h=e1c9a276be5f47fda98de0762e8781ad6df4484e;hb=d25dd0ee5e47188c3ea9ad2918f627cfac97ddbd;hp=f1812e8db73fe10ece10ce23db12394dcc05d624;hpb=9d0857e01495c77accb2c7a2ee34ec4573261b24;p=civicrm-core.git diff --git a/CRM/Admin/Form/Tag.php b/CRM/Admin/Form/Tag.php index f1812e8db7..e1c9a276be 100644 --- a/CRM/Admin/Form/Tag.php +++ b/CRM/Admin/Form/Tag.php @@ -1,7 +1,7 @@ setPageTitle($this->_isTagSet ? ts('Tag Set') : ts('Tag')); + if ($this->_action == CRM_Core_Action::DELETE) { if ($this->_id && $tag = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_Tag', $this->_id, 'name', 'parent_id')) { - CRM_Core_Session::setStatus(ts("This tag cannot be deleted. You must delete all its child tags ('%1', etc) prior to deleting this tag.", array(1 => $tag)), ts('Sorry'), 'error'); $url = CRM_Utils_System::url('civicrm/admin/tag', "reset=1"); - CRM_Utils_System::redirect($url); - return TRUE; + CRM_Core_Error::statusBounce(ts("This tag cannot be deleted. You must delete all its child tags ('%1', etc) prior to deleting this tag.", array(1 => $tag)), $url); + } + if ($this->_values['is_reserved'] == 1 && !CRM_Core_Permission::check('administer reserved tags')) { + CRM_Core_Error::statusBounce(ts("You do not have sufficient permission to delete this reserved tag.")); } } else { @@ -65,7 +67,7 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { $this->_isTagSet = TRUE; } - $allTag = array('' => '- ' . ts('select') . ' -') + CRM_Core_BAO_Tag::getTagsNotInTagset(); + $allTag = array('' => ts('- select -')) + CRM_Core_BAO_Tag::getTagsNotInTagset(); if ($this->_id) { unset($allTag[$this->_id]); @@ -73,6 +75,14 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { if (!$this->_isTagSet) { $this->add('select', 'parent_id', ts('Parent Tag'), $allTag, FALSE, array('class' => 'crm-select2')); + + // Tagsets are not selectable by definition so only include the selectable field if NOT a tagset. + $selectable = $this->add('checkbox', 'is_selectable', ts('Selectable?')); + // Selectable should be checked by default when creating a new tag + if ($this->_action == CRM_Core_Action::ADD) { + $selectable->setValue(1); + } + } $this->assign('isTagSet', $this->_isTagSet); @@ -82,15 +92,15 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { $this->add('text', 'name', ts('Name'), CRM_Core_DAO::getAttribute('CRM_Core_DAO_Tag', 'name'), TRUE ); - $this->addRule('name', ts('Name already exists in Database.'), 'objectExists', array('CRM_Core_DAO_Tag', $this->_id)); + $this->addRule('name', ts('Name already exists in Database.'), 'objectExists', array( + 'CRM_Core_DAO_Tag', + $this->_id, + )); $this->add('text', 'description', ts('Description'), CRM_Core_DAO::getAttribute('CRM_Core_DAO_Tag', 'description') ); - //@lobo haven't a clue why the checkbox isn't displayed (it should be checked by default - $this->add('checkbox', 'is_selectable', ts("If it's a tag or a category")); - $isReserved = $this->add('checkbox', 'is_reserved', ts('Reserved?')); $usedFor = $this->addSelect('used_for', array('multiple' => TRUE, 'option_url' => NULL)); @@ -119,9 +129,8 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { } /** - * Function to process the form + * Process the form submission * - * @access public * * @return void */ @@ -147,6 +156,10 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { $params['is_reserved'] = 0; } + if (!isset($params['is_selectable'])) { + $params['is_selectable'] = 0; + } + if ($this->_action == CRM_Core_Action::DELETE) { if ($this->_id > 0) { $tag = civicrm_api3('tag', 'getsingle', array('id' => $this->_id)); @@ -159,6 +172,5 @@ class CRM_Admin_Form_Tag extends CRM_Admin_Form { CRM_Core_Session::setStatus(ts('The tag \'%1\' has been saved.', array(1 => $tag->name)), ts('Saved'), 'success'); } } - //end of function -} +}