demo_umami.profile

Same filename in other branches
  1. 9 core/profiles/demo_umami/demo_umami.profile
  2. 8.9.x core/profiles/demo_umami/demo_umami.profile
  3. 11.x core/profiles/demo_umami/demo_umami.profile

Enables modules and site configuration for a demo_umami site installation.

File

core/profiles/demo_umami/demo_umami.profile

View source
<?php


/**
 * @file
 * Enables modules and site configuration for a demo_umami site installation.
 */
use Drupal\contact\Entity\ContactForm;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\Url;

/**
 * Implements hook_help().
 */
function demo_umami_help($route_name, RouteMatchInterface $route_match) {
    switch ($route_name) {
        case 'help.page.demo_umami':
            $output = '';
            $output .= '<h2>' . t('About') . '</h2>';
            $output .= '<p>' . t('Umami is an example food magazine website that demonstrates some of the features of Drupal core. It is intended to be used as an example site, rather than as a foundation for building your own site. For more information, see the <a href=":demo_umami">online documentation for the Umami installation profile</a>.', [
                ':demo_umami' => 'https://www.drupal.org/node/2941833',
            ]) . '</p>';
            $output .= '<h2>' . t('Uses') . '</h2>';
            $output .= '<h3>' . t('Demonstrating Drupal core functionality') . '</h3>';
            $output .= '<p>' . t('You can look around the site to get ideas for what kinds of features Drupal is capable of, and to see how an actual site can be built using Drupal core.') . '</p>';
            $output .= '<h3>' . t('Sample content') . '</h3>';
            $output .= '<p>' . t('The Umami profile is very handy if you are developing a feature and need some sample content.') . '</p>';
            $output .= '<h2>' . t('What to do when you are ready to build your Drupal website') . '</h2>';
            $output .= '<p>' . t("Once you've tried Drupal using Umami and want to build your own site, simply reinstall Drupal and select a different installation profile (such as Standard) from the install screen.") . '</p>';
            return $output;
    }
}

/**
 * Implements hook_form_FORM_ID_alter() for install_configure_form().
 *
 * Allows the profile to alter the site configuration form.
 */
function demo_umami_form_install_configure_form_alter(&$form, FormStateInterface $form_state) {
    $form['site_information']['site_name']['#default_value'] = 'Umami Food Magazine';
    $form['#submit'][] = 'demo_umami_form_install_configure_submit';
}

/**
 * Submission handler to sync the contact.form.feedback recipient.
 */
function demo_umami_form_install_configure_submit($form, FormStateInterface $form_state) {
    $site_mail = $form_state->getValue('site_mail');
    ContactForm::load('feedback')->setRecipients([
        $site_mail,
    ])
        ->trustData()
        ->save();
    $password = $form_state->getValue('account')['pass'];
    demo_umami_set_users_passwords($password);
}

/**
 * Sets the password of admin to be the password for all users.
 */
function demo_umami_set_users_passwords($admin_password) {
    // Collect the IDs of all users with roles editor or author.
    $ids = \Drupal::entityQuery('user')->accessCheck(FALSE)
        ->condition('roles', [
        'author',
        'editor',
    ], 'IN')
        ->execute();
    $users = \Drupal::entityTypeManager()->getStorage('user')
        ->loadMultiple($ids);
    foreach ($users as $user) {
        $user->setPassword($admin_password);
        $user->save();
    }
}

/**
 * Implements hook_toolbar().
 */
function demo_umami_toolbar() {
    // Add a warning about using an experimental profile.
    // @todo This can be removed once a generic warning for experimental profiles
    //   has been introduced. https://www.drupal.org/project/drupal/issues/2934374
    $items['experimental-profile-warning'] = [
        '#weight' => 3400,
        '#cache' => [
            'contexts' => [
                'route',
            ],
        ],
    ];
    // Show warning only on administration pages.
    $admin_context = \Drupal::service('router.admin_context');
    if ($admin_context->isAdminRoute()) {
        $link_to_help_page = \Drupal::moduleHandler()->moduleExists('help') && \Drupal::currentUser()->hasPermission('access help pages');
        $items['experimental-profile-warning']['#type'] = 'toolbar_item';
        $items['experimental-profile-warning']['tab'] = [
            '#type' => 'inline_template',
            '#template' => '<a class="toolbar-warning" href="{{ more_info_link }}">This site is intended for demonstration purposes.</a>',
            '#context' => [
                // Link directly to the drupal.org documentation if the help pages
                // aren't available.
'more_info_link' => $link_to_help_page ? Url::fromRoute('help.page', [
                    'name' => 'demo_umami',
                ]) : 'https://www.drupal.org/node/2941833',
            ],
            '#attached' => [
                'library' => [
                    'demo_umami/toolbar-warning',
                ],
            ],
        ];
    }
    return $items;
}

Functions

Title Deprecated Summary
demo_umami_form_install_configure_form_alter Implements hook_form_FORM_ID_alter() for install_configure_form().
demo_umami_form_install_configure_submit Submission handler to sync the contact.form.feedback recipient.
demo_umami_help Implements hook_help().
demo_umami_set_users_passwords Sets the password of admin to be the password for all users.
demo_umami_toolbar Implements hook_toolbar().

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.