registration.entity.inc in Entity Registration 7.2
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, $registrant_id, $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();
$registrant_type = $wrapper->registrant
->type();
$registrant = $wrapper->registrant
->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->registrant_mail
->value(),
),
),
'#classes' => 'field field-label-inline clearfix',
);
// Link to host entity.
$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' => '',
);
}
$build['registrant'] = array(
'#theme' => 'registration_property_field',
'#label' => t('Registrant'),
'#items' => array(
array(
'#markup' => theme('registration_registrant_link', array(
'registrant_type' => $registrant_type,
'registrant' => $registrant,
)),
),
),
'#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(),
);
}
}
Classes
Name![]() |
Description |
---|---|
Registration | Main class for Registration entities. |