');
$breadcrumb[] = l('Administration', 'admin');
$breadcrumb[] = l('Tripal', 'admin/tripal');
$breadcrumb[] = l('Biological Data', 'admin/tripal/bundles');
drupal_set_breadcrumb($breadcrumb);
/* // Add the view
$view = views_embed_view('tripal_feature_admin_features','default');
if (isset($view)) {
$output .= $view;
}
else {
$output .= 'The Feature module uses primarily views to provide an '
. 'administrative interface. Currently one or more views needed for this '
. 'administrative interface are disabled. Click each of the following links to '
. 'enable the pertinent views:
';
$output .= '';
$output .= '- '.l('Features View', 'admin/tripal/chado/tripal_feature/views/features/enable').'
';
$output .= '
';
}
// Add a summary chart.
//-----------------------------------
$output .= theme('tripal_feature_bar_chart_type_organism_summary');
drupal_add_js('
Drupal.behaviors.tripalFeature_moveAdminSummaryChart = {
attach: function (context, settings) {
jQuery("#tripal-feature-admin-summary").insertBefore( jQuery(".view-filters") );
}};
', 'inline'); */
return $output;
}
/**
*
*/
function tripal_entities_content_view() {
$form = drupal_get_form('tripal_entities_content_overview_form');
$output = drupal_render($form);
// set the breadcrumb
$breadcrumb = array();
$breadcrumb[] = l('Home', '');
$breadcrumb[] = l('Administration', 'admin');
drupal_set_breadcrumb($breadcrumb);
return $output;
}
function tripal_entities_publish() {
$form = drupal_get_form('tripal_entities_entity_form');
$output = drupal_render($form);
// set the breadcrumb
$breadcrumb = array();
$breadcrumb[] = l('Home', '');
$breadcrumb[] = l('Administration', 'admin');
drupal_set_breadcrumb($breadcrumb);
return $output;
}
/**
*
* @param unknown $form
* @param unknown $form_state
* @return multitype:
*/
function tripal_entities_content_overview_form($form, &$form_state) {
$form = array();
$entities = db_select('tripal_entity', 'td')
->fields('td')
->orderBy('created', 'DESC')//ORDER BY created
->range(0,25)
->execute();
$headers = array('Title', 'Vocabulary', 'Term', 'Author', 'Status', 'Updated', 'Operations');
$rows = array();
while ($entity = $entities->fetchObject()) {
$author = user_load($entity->uid);
$rows[] = array(
l($entity->title, 'data/' . $entity->id),
$entity->type,
$entity->bundle,
l($author->name, 'user/' . $entity->uid),
$entity->status == 1 ? 'published' : 'unpublished',
format_date($entity->changed, 'short'),
l('edit', 'data/' . $entity->id . '/edit') . ' ' .
l('delete', 'data/' . $entity->id . '/delete')
);
}
$table_vars = array(
'header' => $headers,
'rows' => $rows,
'attributes' => array(),
'sticky' => TRUE,
'caption' => '',
'colgroups' => array(),
'empty' => '',
);
$results_table = theme('table', $table_vars);
$form['results'] = array(
'#markup' => $results_table
);
return $form;
}
/**
*
* @param unknown $form
* @param unknown $form_state
* @return multitype:
*/
function tripal_entities_admin_bundles_form($form, &$form_state) {
$form = array();
// Set the defaults.
$cv_id = NULL;
$term_name = NULL;
// Set defaults using the form state.
if (array_key_exists('values', $form_state)) {
$cv_id = array_key_exists('cv_id', $form_state['values']) ? $form_state['values']['cv_id'] : NULL;
$term_name = array_key_exists('term_name', $form_state['values']) ? $form_state['values']['term_name'] : NULL;
}
// Let the user select the vocabulary and tripal_entity but only if they haven't
// already selected a tripal_entity.
$sql = "
SELECT CV.cv_id, CV.name
FROM {cv} CV
ORDER BY CV.name
";
$vocabs = chado_query($sql);
$cvs = array();
while ($vocab = $vocabs->fetchObject()) {
$cvs[$vocab->cv_id] = $vocab->name;
}
$form['cv_id'] = array(
'#type' => 'select',
'#title' => t('Vocabulary'),
'#options' => $cvs,
'#required' => FALSE,
'#description' => t('Select a vocabulary to view potential data types in the chart below. Limit the chart to only published data types by selecting the checkbox.'),
'#default_value' => $cv_id,
'#ajax' => array(
'callback' => "tripal_entities_admin_bundles_form_ajax_callback",
'wrapper' => 'tripal_entities_admin_bundles_form',
'effect' => 'fade',
'method' => 'replace'
)
);
$form['refresh_bundles'] = array(
'#type' => 'submit',
'#value' => t('Refresh Data Types'),
'#name' => 'refresh_bundles',
);
$form['publish_new_data'] = array(
'#type' => 'submit',
'#value' => t('Publish New Data'),
'#name' => 'publish_new_data',
);
$form['#prefix'] = '';
$form['#suffix'] = '
';
return $form;
}
/**
* Submit a job to populate the entity tables
* This operation makes available data types in the database publishable
*/
function tripal_entities_admin_bundles_form_submit($form, $form_state) {
global $user;
if ($form_state['clicked_button']['#name'] == 'refresh_bundles') {
tripal_add_job('Create publishable data types', 'tripal_entity', 'tripal_entities_populate_entity_tables', array(), $user->uid);
}
if ($form_state['clicked_button']['#name'] == 'publish_new_data') {
}
}
/**
*
* @param unknown $form
* @param unknown $form_state
* @return multitype:
*/
function tripal_entities_admin_publish_form($form, &$form_state) {
$form = array();
// Set the defaults.
$cv_id = NULL;
$term_name = NULL;
// Set defaults using the form state.
if (array_key_exists('values', $form_state)) {
$cv_id = array_key_exists('cv_id', $form_state['values']) ? $form_state['values']['cv_id'] : NULL;
$term_name = array_key_exists('term_name', $form_state['values']) ? $form_state['values']['term_name'] : NULL;
}
// Let the user select the vocabulary and tripal_entity but only if they haven't
// already selected a tripal_entity.
// $sql = "
// SELECT CV.cv_id, CV.name
// FROM {tripal_vocabulary} TET
// INNER JOIN {cv} CV on CV.cv_id = TET.cv_id
// ORDER BY CV.name
// ";
// $vocabs = chado_query($sql);
// $cvs = array();
// while ($vocab = $vocabs->fetchObject()) {
// $cvs[$vocab->cv_id] = $vocab->name;
// }
$cvs = tripal_get_cv_select_options();
$form['cv_id'] = array(
'#type' => 'select',
'#title' => t('Vocabulary'),
'#options' => $cvs,
'#required' => TRUE,
'#description' => t('Select a vocabulary that contains the term you would like to set as publishable. Only vocabularies that are linked to data are shown.'),
'#default_value' => $cv_id,
'#ajax' => array(
'callback' => "tripal_entities_admin_publish_form_ajax_callback",
'wrapper' => 'tripal_entities_admin_publish_form',
'effect' => 'fade',
'method' => 'replace'
)
);
// If we have a CV ID then we want to provide an autocomplete field
if ($cv_id) {
$form['cvterm_select']['term_name'] = array(
'#title' => t('Data Type'),
'#type' => 'textfield',
'#description' => t("Please enter the name of the data type to set as publishable. The data type must be a valid term in the selected vocabulary. This field will autopopulate as you type to help find available data types."),
'#required' => TRUE,
'#default_value' => $term_name,
'#autocomplete_path' => "admin/tripal/chado/tripal_cv/cvterm/auto_name/$cv_id",
);
$form['cvterm_select']['select_button'] = array(
'#type' => 'submit',
'#value' => t('Publish Data'),
'#name' => 'publish',
);
}
$form['#prefix'] = '';
$form['#suffix'] = '
';
return $form;
}
/**
* An Ajax callback for the tripal_entities_admin_publish_form..
*/
function tripal_entities_admin_publish_form_ajax_callback($form, $form_state) {
// return the form so Drupal can update the content on the page
return $form;
}
/**
* Implements hook_validate() for the tripal_entities_admin_publish_form.
*
*/
function tripal_entities_admin_publish_form_validate($form, &$form_state) {
$cv_id = $form_state['values']['cv_id'];
$term_name = $form_state['values']['term_name'];
// Make sure the term_name is a real term in the vocabulary.
$type = tripal_get_cvterm(array(
'name' => $term_name,
'cv_id' => $cv_id
));
if (!$type) {
form_set_error('term_name', t("The data type is not a valid name for the selected vocabulary."));
}
// Make sure the term is used in the site:
$values = array(
'cvterm_id' => $type->cvterm_id,
);
$bundles = chado_select_record('tripal_term', array('term_id'), $values);
if (count($bundles) == 0) {
form_set_error('term_name', t("The data type, %type, is not associated with data on this site and thus cannot be set as publishable.", array('%type' => $term_name)));
}
// Make sure the term is not already published.
$values = array(
'cvterm_id' => $type->cvterm_id,
'publish' => 1,
);
$bundles = chado_select_record('tripal_term', array('term_id'), $values);
if (count($bundles) > 0) {
form_set_error('term_name', t("This data type is already set as publishable."));
}
}
/**
* Implements hook_submit() for the tripal_entities_admin_publish_form.
*
*/
function tripal_entities_admin_publish_form_submit($form, &$form_state) {
$cv_id = $form_state['values']['cv_id'];
$term_name = $form_state['values']['term_name'];
// Get the data type using the $term_name and $cv_id.
$cvterm = chado_generate_var('cvterm', array('cv_id' => $cv_id, 'name' => $term_name));
// Start the transaction.
$transaction = db_transaction();
try {
// We don't need to check if the vocabulary is used because the
// form only shows those vocabs that are used.
// Mark this entity as published.
$match = array('cv_id' => $cv_id);
$values = array('publish' => 1);
$success = chado_update_record('tripal_vocabulary', $match, $values);
if (!$success) {
throw new Exception('Cannot set the vocabulary as publishable');
}
// We have already checked in the validate if the term already exists
// as a bundle. So, if we're here we can enable it.
$match = array('cvterm_id' => $cvterm->cvterm_id);
$values = array('publish' => 1);
$success = chado_update_record('tripal_term', $match, $values);
if (!$success) {
throw new Exception('Cannot set the data type as publishable');
}
// Create the bundle name and entity type name.
$bundle_name = $cvterm->dbxref_id->db_id->name . '_' . $cvterm->dbxref_id->accession;
$entity_type_name = $cvterm->dbxref_id->db_id->name;
// Clear the entity cache so that Drupal will read our
// hook_entity_info() implementation which now will have the entities
// described because we set the publish column to 1 in the tripal_term
// table.
global $language;
$langcode = $language->language;
cache_clear_all("entity_info:$langcode", 'cache');
// The TripalBundle Entity manages the bundles we have available.
// Therefore, we need to add a new entity for each bundle "type".
$vals = array(
'label' => $bundle_name . ' (' . $cvterm->name . ')',
'type' => $entity_type_name,
'bundle' => $bundle_name,
'data' => serialize(array()),
'module' => 'tripal_entities'
);
$tripal_bundle = new TripalBundle($vals, $entity_type_name . '_bundle');
$tripal_bundle->save();
// Allow modules to now add fields to the bundle
module_invoke_all('add_bundle_fields', $entity_type_name, $bundle_name, $cvterm);
drupal_set_message(t('Data type, %type, is now set as publishable.', array('%type' => $term_name)));
}
catch (Exception $e) {
$transaction->rollback();
drupal_set_message('Failure publishing this data type: ' . $e->getMessage(), 'error');
watchdog_exception('trp_entities', $e);
}
}
/**
* Implements hook_chado_field_alter.
*
* This function is used when new Chado fields are addd to an Entity. It
* allows modules to customize the field, widget types and settings for
* a field before it is created.
*
* @param $field
*/
function hook_chado_field_alter(&$field) {
// TODO: add example code for how to use this hook.
}
/**
*
* @param unknown $form
* @param unknown $form_state
* @return multitype:
*/
function tripal_entities_admin_access_form($form, &$form_state) {
$form = array();
return $form;
}