diff -r 07239de796bb -r e756a8c72c3d cms/drupal/includes/theme.maintenance.inc --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cms/drupal/includes/theme.maintenance.inc Fri Sep 08 12:04:06 2017 +0200 @@ -0,0 +1,211 @@ +base_theme)) { + $base_theme[] = $new_base_theme = $themes[$themes[$ancestor]->base_theme]; + $ancestor = $themes[$ancestor]->base_theme; + } + _drupal_theme_initialize($themes[$theme], array_reverse($base_theme), '_theme_load_offline_registry'); + + // These are usually added from system_init() -except maintenance.css. + // When the database is inactive it's not called so we add it here. + $path = drupal_get_path('module', 'system'); + drupal_add_css($path . '/system.base.css'); + drupal_add_css($path . '/system.admin.css'); + drupal_add_css($path . '/system.menus.css'); + drupal_add_css($path . '/system.messages.css'); + drupal_add_css($path . '/system.theme.css'); + drupal_add_css($path . '/system.maintenance.css'); +} + +/** + * Builds the registry when the site needs to bypass any database calls. + */ +function _theme_load_offline_registry($theme, $base_theme = NULL, $theme_engine = NULL) { + return _theme_build_registry($theme, $base_theme, $theme_engine); +} + +/** + * Returns HTML for a list of maintenance tasks to perform. + * + * @param $variables + * An associative array containing: + * - items: An associative array of maintenance tasks. + * - active: The key for the currently active maintenance task. + * + * @ingroup themeable + */ +function theme_task_list($variables) { + $items = $variables['items']; + $active = $variables['active']; + + $done = isset($items[$active]) || $active == NULL; + $output = '

Installation tasks

'; + $output .= '
    '; + + foreach ($items as $k => $item) { + if ($active == $k) { + $class = 'active'; + $status = '(' . t('active') . ')'; + $done = FALSE; + } + else { + $class = $done ? 'done' : ''; + $status = $done ? '(' . t('done') . ')' : ''; + } + $output .= ''; + $output .= $item; + $output .= ($status ? '' . $status . '' : ''); + $output .= ''; + } + $output .= '
'; + return $output; +} + +/** + * Returns HTML for the installation page. + * + * Note: this function is not themeable. + * + * @param $variables + * An associative array containing: + * - content: The page content to show. + */ +function theme_install_page($variables) { + drupal_add_http_header('Content-Type', 'text/html; charset=utf-8'); + return theme('maintenance_page', $variables); +} + +/** + * Returns HTML for the update page. + * + * Note: this function is not themeable. + * + * @param $variables + * An associative array containing: + * - content: The page content to show. + * - show_messages: Whether to output status and error messages. + * FALSE can be useful to postpone the messages to a subsequent page. + */ +function theme_update_page($variables) { + drupal_add_http_header('Content-Type', 'text/html; charset=utf-8'); + return theme('maintenance_page', $variables); +} + +/** + * Returns HTML for a results report of an operation run by authorize.php. + * + * @param $variables + * An associative array containing: + * - messages: An array of result messages. + * + * @ingroup themeable + */ +function theme_authorize_report($variables) { + $messages = $variables['messages']; + $output = ''; + if (!empty($messages)) { + $output .= '
'; + foreach ($messages as $heading => $logs) { + $items = array(); + foreach ($logs as $number => $log_message) { + if ($number === '#abort') { + continue; + } + $items[] = theme('authorize_message', array('message' => $log_message['message'], 'success' => $log_message['success'])); + } + $output .= theme('item_list', array('items' => $items, 'title' => $heading)); + } + $output .= '
'; + } + return $output; +} + +/** + * Returns HTML for a single log message from the authorize.php batch operation. + * + * @param $variables + * An associative array containing: + * - message: The log message. + * - success: A boolean indicating failure or success. + * + * @ingroup themeable + */ +function theme_authorize_message($variables) { + $message = $variables['message']; + $success = $variables['success']; + if ($success) { + $item = array('data' => $message, 'class' => array('success')); + } + else { + $item = array('data' => '' . $message . '', 'class' => array('failure')); + } + return $item; +}