4 +--------------------------------------------------------------------+
5 | Copyright CiviCRM LLC. All rights reserved. |
7 | This work is published under the GNU AGPLv3 license with some |
8 | permitted exceptions and without any warranty. For full license |
9 | and copyright information, see https://civicrm.org/licensing |
10 +--------------------------------------------------------------------+
14 * Class CRM_Member_Tokens
16 * Generate "member.*" tokens.
18 * This TokenSubscriber was produced by refactoring the code from the
19 * scheduled-reminder system with the goal of making that system
20 * more flexible. The current implementation is still coupled to
21 * scheduled-reminders. It would be good to figure out a more generic
22 * implementation which is not tied to scheduled reminders, although
23 * that is outside the current scope.
25 class CRM_Member_Tokens
extends CRM_Core_EntityTokens
{
28 * Get the entity name for api v4 calls.
32 protected function getApiEntityName(): string {
37 * List out the fields that are exposed.
39 * For historical reasons these are the only exposed fields.
41 * It is also possible to list 'skippedFields'
45 protected function getExposedFields(): array {
58 * @throws \CiviCRM_API3_Exception
60 public function evaluateToken(\Civi\Token\TokenRow
$row, $entity, $field, $prefetch = NULL) {
61 if ($field === 'fee') {
62 $membershipType = CRM_Member_BAO_MembershipType
::getMembershipType($this->getFieldValue($row, 'membership_type_id'));
63 $row->tokens($entity, $field, \CRM_Utils_Money
::formatLocaleNumericRoundedForDefaultCurrency($membershipType['minimum_fee']));
66 parent
::evaluateToken($row, $entity, $field, $prefetch);
71 * Get fields which need to be returned to render another token.
75 public function getDependencies(): array {
76 return ['fee' => 'membership_type_id'];
80 * Get any tokens with custom calculation.
82 * In this case 'fee' should be converted to{membership.membership_type_id.fee}
83 * but we don't have the formatting support to do that with no
84 * custom intervention yet.
86 protected function getBespokeTokens(): array {
89 'title' => ts('Membership Fee'),
91 'type' => 'calculated',
93 'data_type' => 'integer',