t('Term parent'), 'keyword' => 'parent_term', 'description' => t('Adds a taxonomy term parent from a term context.'), 'required context' => new ctools_context_required(t('Term'), 'term'), 'context' => 'ctools_term_parent_context', 'settings form' => 'ctools_term_parent_settings_form', 'settings form validate' => 'ctools_term_parent_settings_form_validate', ); /** * Return a new context based on an existing context. */ function ctools_term_parent_context($context, $conf) { // If unset it wants a generic, unfilled context, which is just NULL. if (empty($context->data)) { return ctools_context_create_empty('term'); } if (isset($context->data)) { $result = db_fetch_array(db_query("SELECT t1.* FROM {term_hierarchy} t1 INNER JOIN {term_hierarchy} t2 ON t1.tid = t2.parent WHERE t2.tid = %d", $context->data->tid)); // If top level term, keep looking up until we see a top level. if ($conf['type'] == 'top') { // If looking for top level, and there are no parents at all, make sure // the current term is the 'top level'. if (empty($result)) { $result['tid'] = $context->data->tid; } while (!empty($result['parent'])) { $result = db_fetch_array(db_query("SELECT * FROM {term_hierarchy} WHERE tid = %d", $result['parent'])); } } // Load the term. if ($result) { $term = taxonomy_get_term($result['tid']); return ctools_context_create('term', $term); } } } /** * Settings form for the relationship. */ function ctools_term_parent_settings_form($conf) { $form['type'] = array( '#type' => 'select', '#title' => t('Relationship type'), '#options' => array('parent' => t('Immediate parent'), 'top' => t('Top level term')), '#default_value' => $conf['type'], ); return $form; }