Yeni kullanıcı için e-posta şablonunu nasıl değiştirebilirim


10

Yeni bir müşteri eklediğimde e-posta yeni kullanıcıya şu biçimde gider:

From: WordPress [wordpress@siteurl.com]
Subject: [site name] Your user name and password
Message:
         username: user
         Password: password
         siteurl.com/wp-login.php

Şimdi bu biçimi değiştirmek istiyorum Şunun gibi:

From: My Site Name [info@siteurl.com]
Subject: siteurl.com customer account activated
Message:
       Your customer account has been activated.

       Your Login credentials are:

       Username: user email
       Password: password

       Thanks,
       abcd

Bu cevabı denedim ama işe yaramıyor.

Bunu nasıl yapabilirim?

Yanıtlar:


17

2018 ve sonrası kullanıcılar için:

David Gard'ın cevabı hala çalışıyor, ancak eski ve bunu yapmanın yeni daha iyi / temiz bir yolu var (artık bir eklentiye gerek yok).

WordPress 4.9.0'dan beri kayıt e-postalarını özelleştirmek için kullanabileceğiniz yeni filtreler vardır:

Yönetici'ye gönderilen e-postalarda kullanım örneği (bunu temanızın işlevlerine yapıştırabilirsiniz.php ):

add_filter( 'wp_new_user_notification_email_admin', 'custom_wp_new_user_notification_email', 10, 3 );

function custom_wp_new_user_notification_email( $wp_new_user_notification_email, $user, $blogname ) {
    $wp_new_user_notification_email['subject'] = sprintf( '[%s] New user %s registered.', $blogname, $user->user_login );
    $wp_new_user_notification_email['message'] = sprintf( "%s ( %s ) has registerd to your blog %s.", $user->user_login, $user->user_email, $blogname );
    return $wp_new_user_notification_email;
}

7

Yeni kullanıcı bildirim e-postası oluşturulur ve wp-include / plugable.php dosyasındawp_new_user_notification() bulunan işlev tarafından gönderilir.

Bu funciton içinde, e-postanın çıktısını değiştirmenize izin verecek bir filtre kancası yoktur, ancak elbette bir eklenti aracılığıyla herhangi bir takılabilir işlevin üzerine yazabilirsiniz.

Not - Eklenebilir işlevlerin üzerine, temanızın içinden değil, bir eklenti içinden yazabilirsiniz.

Takılabilir işlevler ve mevcut olanların tam listesi hakkında daha fazla bilgi için buraya bakın - http://codex.wordpress.org/Pluggable_Functions

Bu kod, wp-include / plugable.php yerine bir eklenti oluşturacaktır ( wp-content / plugins / içine kendi dosyasında kaydedin ).

Senin için özelleştirmedim, ama bu seni yoluna koymalı.

<?php
/**
 * Plugin Name: Custom new user notification email
 * Description: Overwrites the pluggable 'wp_new_user_notification()' plugin to allow the sending of a custom email
 * Author: David Gard
 * Version: 1.0
 */

if ( !function_exists('wp_new_user_notification') ) :
/**
 * Pluggable - Email login credentials to a newly-registered user
 *
 * A new user registration notification is also sent to admin email.
 *
 * @since 2.0.0
 *
 * @param int    $user_id        User ID.
 * @param string $plaintext_pass Optional. The user's plaintext password. Default empty.
 */
function wp_new_user_notification($user_id, $plaintext_pass = ''){

    $user = get_userdata($user_id);

    // The blogname option is escaped with esc_html on the way into the database in sanitize_option
    // we want to reverse this for the plain text arena of emails.
    $blogname = wp_specialchars_decode(get_option('blogname'), ENT_QUOTES);

    $message  = sprintf(__('New user registration on your site %s:'), $blogname) . "\r\n\r\n";
    $message .= sprintf(__('Username: %s'), $user->user_login) . "\r\n\r\n";
    $message .= sprintf(__('E-mail: %s'), $user->user_email) . "\r\n";

    @wp_mail(get_option('admin_email'), sprintf(__('[%s] New User Registration'), $blogname), $message);

    if ( empty($plaintext_pass) )
        return;

    $message  = sprintf(__('Username: %s'), $user->user_login) . "\r\n";
    $message .= sprintf(__('Password: %s'), $plaintext_pass) . "\r\n";
    $message .= wp_login_url() . "\r\n";

    wp_mail($user->user_email, sprintf(__('[%s] Your username and password'), $blogname), $message);

}
endif;

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.