X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=CRM%2FCore%2FTokenTrait.php;h=2f995b432669c9b4e27eb6859622f36f81c7b3a5;hb=7be60c2d30b539f58ec1c365c284e7f26573b720;hp=356bdc7fd09828905aa28769869cc89b18aff77a;hpb=77c3b7089c290880a7599cc77cdbe87fa6958c13;p=civicrm-core.git diff --git a/CRM/Core/TokenTrait.php b/CRM/Core/TokenTrait.php index 356bdc7fd0..2f995b4326 100644 --- a/CRM/Core/TokenTrait.php +++ b/CRM/Core/TokenTrait.php @@ -58,17 +58,15 @@ trait CRM_Core_TokenTrait { /** * Find the fields that we need to get to construct the tokens requested. - * @param array $activeTokens list of active tokens + * * @return array list of fields needed to generate those tokens */ - public function getReturnFields($activeTokens) { + public function getReturnFields(): array { // Make sure we always return something $fields = ['id']; - $tokensInUse = array_intersect( - $activeTokens, - array_merge(array_keys(self::getBasicTokens()), array_keys(self::getCustomFieldTokens())) - ); + $tokensInUse = + array_merge(array_keys(self::getBasicTokens()), array_keys(self::getCustomFieldTokens())); foreach ($tokensInUse as $token) { if (isset(self::$fieldMapping[$token])) { $fields = array_merge($fields, self::$fieldMapping[$token]); @@ -86,7 +84,10 @@ trait CRM_Core_TokenTrait { */ protected function getCustomFieldTokens(): array { if (!isset($this->customFieldTokens)) { - $this->customFieldTokens = \CRM_Utils_Token::getCustomFieldTokens(ucfirst($this->getEntityName())); + $this->customFieldTokens = []; + foreach (CRM_Core_BAO_CustomField::getFields(ucfirst($this->getEntityName())) as $id => $info) { + $this->customFieldTokens['custom_' . $id] = $info['label'] . ' :: ' . $info['groupTitle']; + } } return $this->customFieldTokens; }