/**
 * @file
 * User behaviors.
 */
(function ($, Drupal, drupalSettings) {
  /**
   * Attach handlers to evaluate the strength of any password fields and to
   * check that its confirmation is correct.
   *
   * @type {Drupal~behavior}
   *
   * @prop {Drupal~behaviorAttach} attach
   *   Attaches password strength indicator and other relevant validation to
   *   password fields.
   */
  Drupal.behaviors.password = {
    attach(context, settings) {
      const $passwordInput = $(context).find('input.js-password-field').once('password');
      if ($passwordInput.length) {
        const translate = settings.password;
        const $passwordInputParent = $passwordInput.parent();
        const $passwordInputParentWrapper = $passwordInputParent.parent();
        let $passwordSuggestions;
        // Add identifying class to password element parent.
        $passwordInputParent.addClass('password-parent');
        // Add the password confirmation layer.
        $passwordInputParentWrapper
          .find('input.js-password-confirm')
          .parent()
          .append(`
${translate.confirmTitle} 
`)
          .addClass('confirm-parent');
        const $confirmInput = $passwordInputParentWrapper.find('input.js-password-confirm');
        const $confirmResult = $passwordInputParentWrapper.find('div.js-password-confirm');
        const $confirmChild = $confirmResult.find('span');
        // If the password strength indicator is enabled, add its markup.
        if (settings.password.showStrengthIndicator) {
          const passwordMeter = `${translate.strengthTitle}