page-wizard.inc

File

includes/page-wizard.inc

View source
<?php


/**
 * @file
 */

/**
 * Fetch metadata on a specific page_wizard plugin.
 *
 * @param $page_wizard
 *   Name of a panel page_wizard.
 *
 * @return
 *   An array with information about the requested panel page_wizard.
 */
function page_manager_get_page_wizard($page_wizard) {
    ctools_include('plugins');
    return ctools_get_plugins('page_manager', 'page_wizards', $page_wizard);
}

/**
 * Fetch metadata for all page_wizard plugins.
 *
 * @return
 *   An array of arrays with information about all available panel page_wizards.
 */
function page_manager_get_page_wizards() {
    ctools_include('plugins');
    return ctools_get_plugins('page_manager', 'page_wizards');
}

/**
 * Get the cached changes to a given wizard.
 *
 * @return
 *   A $cache object or a clean cache object if none could be loaded.
 */
function page_manager_get_wizard_cache($plugin) {
    if (is_string($plugin)) {
        $plugin = page_manager_get_page_wizard($plugin);
    }
    if (empty($plugin)) {
        return;
    }
    ctools_include('object-cache');
    // Since contexts might be cache, include this so they load.
    ctools_include('context');
    $cache = ctools_object_cache_get('page_manager_page_wizard', $plugin['name']);
    if (!$cache) {
        $cache = page_manager_make_wizard_cache($plugin);
    }
    return $cache;
}
function page_manager_make_wizard_cache($plugin) {
    $cache = new stdClass();
    $cache->plugin = $plugin;
    if ($function = ctools_plugin_get_function($plugin, 'default cache')) {
        $function($cache);
    }
    return $cache;
}

/**
 * Store changes to a task handler in the object cache.
 */
function page_manager_set_wizard_cache($cache) {
    ctools_include('object-cache');
    ctools_object_cache_set('page_manager_page_wizard', $cache->plugin['name'], $cache);
}

/**
 * Remove an item from the object cache.
 */
function page_manager_clear_wizard_cache($name) {
    ctools_include('object-cache');
    ctools_object_cache_clear('page_manager_page_wizard', $name);
}

/**
 * Menu callback for the page wizard.
 */
function page_manager_page_wizard($name, $step = NULL) {
    $plugin = page_manager_get_page_wizard($name);
    if (!$plugin) {
        return MENU_NOT_FOUND;
    }
    // Check for simple access string on plugin.
    if (!empty($plugin['access']) && !user_access($plugin['access'])) {
        return MENU_ACCESS_DENIED;
    }
    // Check for possibly more complex access callback on plugin.
    if (($function = ctools_plugin_get_function($plugin, 'access callback')) && !$function($plugin)) {
        return MENU_ACCESS_DENIED;
    }
    // Create a basic wizard.in form info array and merge it with the
    // plugin's.
    $form_info = array(
        'id' => 'page_manager_page_wizard',
        'show trail' => TRUE,
        'show back' => TRUE,
        'show return' => FALSE,
        'show cancel' => FALSE,
        'next callback' => 'page_manager_page_wizard_next',
        'finish callback' => 'page_manager_page_wizard_finish',
        'path' => "admin/structure/pages/wizard/{$name}/%step",
    );
    $form_info = array_merge_recursive($form_info, $plugin['form info']);
    // If step is unset, go with the basic step.
    if (!isset($step)) {
        $step = current(array_keys($form_info['order']));
        $cache = page_manager_make_wizard_cache($plugin);
    }
    else {
        $cache = page_manager_get_wizard_cache($plugin);
    }
    ctools_include('wizard');
    $form_state = array(
        'plugin' => $plugin,
        'wizard cache' => $cache,
        'type' => 'edit',
        'rerender' => TRUE,
        'step' => $step,
    );
    if (isset($plugin['page title'])) {
        drupal_set_title($plugin['page title']);
    }
    if ($function = ctools_plugin_get_function($form_state['plugin'], 'start')) {
        $function($form_info, $step, $form_state);
    }
    $output = ctools_wizard_multistep_form($form_info, $step, $form_state);
    return $output;
}

/**
 * Callback generated when the add page process is finished.
 */
function page_manager_page_wizard_finish(&$form_state) {
    if ($function = ctools_plugin_get_function($form_state['plugin'], 'finish')) {
        $function($form_state);
    }
    page_manager_clear_wizard_cache($form_state['wizard cache']->plugin['name']);
}

/**
 * Callback generated when the 'next' button is clicked.
 *
 * All we do here is store the cache.
 */
function page_manager_page_wizard_next(&$form_state) {
    if ($function = ctools_plugin_get_function($form_state['plugin'], 'next')) {
        $function($form_state);
    }
    page_manager_set_wizard_cache($form_state['wizard cache']);
}

/**
 * Provide a simple administrative list of all wizards.
 *
 * This is called as a page callback, but can also be used by any module
 * that wants to get a list of wizards for its type.
 */
function page_manager_page_wizard_list($type = NULL) {
    $plugins = page_manager_get_page_wizards();
    if (empty($plugins)) {
        return '<p>' . t('There are no wizards available at this time.') . '</p>';
    }
    uasort($plugins, 'ctools_plugin_sort');
    $output = '<dl class="page-manager-wizards">';
    foreach ($plugins as $id => $plugin) {
        if (!$type || isset($plugin['type']) && $plugin['type'] == $type) {
            $output .= '<dt>' . l($plugin['title'], 'admin/structure/pages/wizard/' . $id) . '</dt>';
            $output .= '<dd class="description">' . $plugin['description'] . '</dd>';
        }
    }
    $output .= '</dl>';
    return $output;
}

Functions

Title Deprecated Summary
page_manager_clear_wizard_cache Remove an item from the object cache.
page_manager_get_page_wizard Fetch metadata on a specific page_wizard plugin.
page_manager_get_page_wizards Fetch metadata for all page_wizard plugins.
page_manager_get_wizard_cache Get the cached changes to a given wizard.
page_manager_make_wizard_cache
page_manager_page_wizard Menu callback for the page wizard.
page_manager_page_wizard_finish Callback generated when the add page process is finished.
page_manager_page_wizard_list Provide a simple administrative list of all wizards.
page_manager_page_wizard_next Callback generated when the 'next' button is clicked.
page_manager_set_wizard_cache Store changes to a task handler in the object cache.