タグ別アーカイブ: Contactform7

Contactform7にサンキュー画面を!

Contactfom7は確認画面はありませんが、それについては以前記事で書きました。

Contactform7で確認用メールアドレスを実装する。

今回はサンキュー画面を実装したいと思います。

実はすごく簡単です!

まず、サンキュー画面の固定ページを作ります。
※urlがhttp://xxx.com/thankyou/だとします。

後はContactform7の設定画面の一番下にある[その他]の部分に以下のコードを入力します。

on_sent_ok: "location.replace('http://xxx.com/thankyou/');"

これで、本格的な問い合わせフォームっぽくなりましたね!

Contactform7で確認用メールアドレスを実装する。

よく、Contactform7で確認画面がないことを指摘しているのですが、
メールアドレス自体の確認が実装できればさほど問題はないですよね?

そこでfunctions.phpに以下のコードを入力

add_filter( 'wpcf7_validate_email', 'wpcf7_text_validation_filter_extend', 11, 2 );
add_filter( 'wpcf7_validate_email*', 'wpcf7_text_validation_filter_extend', 11, 2 );
function wpcf7_text_validation_filter_extend( $result, $tag ) {
    $type = $tag['type'];
    $name = $tag['name'];
    $_POST[$name] = trim( strtr( (string) $_POST[$name], "\n", " " ) );
    if ( 'email' == $type || 'email*' == $type ) {
        if (preg_match('/(.*)_confirm$/', $name, $matches)){
            $target_name = $matches[1];
            if ($_POST[$name] != $_POST[$target_name]) {
                $result['valid'] = false;
                $result['reason'][$name] = '確認用のメールアドレスが一致していません';
            }
        }
    }
    return $result;
}

その後、Contactform7の設定画面にて、以下のコードを入力

メールアドレス (確認用)
[email* your-email_confirm] 

これで確認画面は必要なくなりましたね!