registration.entity.inc in Entity Registration 7
Same filename and directory in other branches
Entity hooks and callbacks for registrations.
File
lib/registration.entity.incView source
<?php
/**
* @file
* Entity hooks and callbacks for registrations.
*/
/**
* Main class for Registration entities.
*/
class Registration extends Entity {
public $registration_id, $type, $entity_id, $entity_type, $anon_mail = NULL, $user_uid = NULL, $count, $author_uid, $state, $created, $updated;
/**
* Specifies the default label, which is picked up by label() by default.
*/
protected function defaultLabel() {
$wrapper = entity_metadata_wrapper('registration', $this);
$host = $wrapper->entity
->value();
if ($host) {
return t('Registration for !title', array(
'!title' => entity_label($this->entity_type, $host),
));
}
return '';
}
/**
* Build content for Registration.
*
* @return array
* Render array for a registration entity.
*/
public function buildContent($view_mode = 'full', $langcode = NULL) {
$build = parent::buildContent($view_mode, $langcode);
$wrapper = entity_metadata_wrapper('registration', $this);
$host_entity_type_info = entity_get_info($this->entity_type);
$host_entity = $wrapper->entity
->value();
$state = $wrapper->state
->value();
$author = $wrapper->author
->value();
$user = $wrapper->user
->value();
list(, , $host_entity_bundle) = entity_extract_ids($this->entity_type, $host_entity);
$host_label = entity_label($this->entity_type, $host_entity);
$host_uri = $host_entity ? entity_uri($this->entity_type, $host_entity) : NULL;
$build['mail'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Email Address'),
'#items' => array(
array(
'#markup' => $wrapper->mail
->value(),
),
),
'#classes' => 'field field-label-inline clearfix',
);
// Link to host entity.
if (isset($host_uri['path'])) {
$host_entity_link_label = isset($host_entity_type_info['bundles'][$host_entity_bundle]['label']) ? '<div class="field-label">' . $host_entity_type_info['bundles'][$host_entity_bundle]['label'] . '</div>' : '';
$build['host_entity_link'] = array(
'#theme' => 'registration_property_field',
'#label' => $host_entity_link_label,
'#items' => array(
array(
'#markup' => l($host_label, $host_uri['path']),
),
),
'#classes' => 'field field-label-inline clearfix',
);
}
$build['created'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Created'),
'#items' => array(
array(
'#markup' => format_date($this->created),
),
),
'#classes' => 'field field-label-inline clearfix',
);
$build['updated'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Updated'),
'#items' => array(
array(
'#markup' => format_date($this->updated),
),
),
'#classes' => 'field field-label-inline clearfix',
);
$build['spaces'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Slots Used'),
'#items' => array(
array(
'#markup' => $this->count,
),
),
'#classes' => 'field field-label-inline clearfix',
);
if ($author) {
$build['author'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Author'),
'#items' => array(
array(
'#markup' => theme('username', array(
'account' => $author,
)),
),
),
'#classes' => 'field field-label-inline clearfix',
'#attributes' => '',
);
}
if ($user) {
$build['user'] = array(
'#theme' => 'registration_property_field',
'#label' => t('User'),
'#items' => array(
array(
'#markup' => theme('username', array(
'account' => $user,
)),
),
),
'#classes' => 'field field-label-inline clearfix',
'#attributes' => '',
);
}
$build['state'] = array(
'#theme' => 'registration_property_field',
'#label' => t('State'),
'#items' => array(
array(
'#markup' => $state ? filter_xss_admin(entity_label('registration_state', $state)) : '',
),
),
'#classes' => 'field field-label-inline clearfix',
);
return $build;
}
/**
* Save registration.
*
* @see entity_save()
*/
public function save() {
// Set a default state if not provided.
$wrapper = entity_metadata_wrapper('registration', $this);
$state = $wrapper->state
->value();
if (!$state) {
$default_state = registration_get_default_state($wrapper
->getBundle());
if ($default_state) {
$this->state = $default_state
->identifier();
}
}
$this->updated = REQUEST_TIME;
if (!$this->registration_id && empty($this->created)) {
$this->created = REQUEST_TIME;
}
return parent::save();
}
/**
* Specify URI.
*/
protected function defaultUri() {
return array(
'path' => 'registration/' . $this
->internalIdentifier(),
);
}
/**
* Determine registrant type relative to a given account.
*
* @object $account
* A Drupal user
*
* @return string|NULL
* Can be me, user, anon or NULL if account is empty and no anon email set.
*/
public function registrant_type($account) {
$reg_type = NULL;
if (!empty($account)) {
if ($account->uid && $account->uid === $this->user_uid) {
$reg_type = REGISTRATION_REGISTRANT_TYPE_ME;
}
elseif ($this->user_uid) {
$reg_type = REGISTRATION_REGISTRANT_TYPE_USER;
}
}
if (!empty($this->anon_mail)) {
$reg_type = REGISTRATION_REGISTRANT_TYPE_ANON;
}
return $reg_type;
}
}
Classes
Name | Description |
---|---|
Registration | Main class for Registration entities. |