Update email.

This commit is contained in:
Hoang Huu 2019-09-20 17:36:01 +07:00
parent 7fe9e71ec0
commit 76dcd7ae25
6 changed files with 329 additions and 330 deletions

View File

@ -120,6 +120,7 @@ window.opalestate_messages = function() {
function make_ajax ( data, _this ) {
$( '.opalestate-message-notify', _this ).remove();
var action = $( _this ).data('action')? $( _this ).data('action') : 'send_email_contact';
console.log(action)
toggle_submit_button( _this );
$.ajax({
type : 'POST',
@ -135,6 +136,9 @@ window.opalestate_messages = function() {
}
toggle_submit_button( _this );
}
},
error: function( response ) {
console.log(response)
}
});
}

View File

@ -13,7 +13,9 @@
*/
// Exit if accessed directly
if ( !defined( 'ABSPATH' ) ) exit;
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* @class OpalMembership_Checkout
@ -30,26 +32,26 @@ class Opalestate_Emails {
self::load();
add_action( 'opalestate_processed_new_submission' , array( __CLASS__ , 'new_submission_email'), 10, 2 );
add_action( 'opalestate_processed_new_submission', [ __CLASS__, 'new_submission_email' ], 10, 2 );
//add_action( 'opalestate_processed_edit_submission' , array( __CLASS__ , 'new_submission_email'), 10, 2 );
if( is_admin() ){
add_filter( 'opalestate_settings_tabs', array( __CLASS__, 'setting_email_tab'), 1 );
add_filter( 'opalestate_registered_emails_settings', array( __CLASS__, 'setting_email_fields'), 10, 1 );
if ( is_admin() ) {
add_filter( 'opalestate_settings_tabs', [ __CLASS__, 'setting_email_tab' ], 1 );
add_filter( 'opalestate_registered_emails_settings', [ __CLASS__, 'setting_email_fields' ], 10, 1 );
}
$enable_approve_property_email = opalestate_get_option( 'enable_approve_property_email' );
if ( $enable_approve_property_email == 'on' ) {
add_action( 'transition_post_status', array( __CLASS__, 'send_email_when_publish_property') , 10, 3 );
add_action( 'opalestate_processed_approve_publish_property', array( __CLASS__, 'approve_publish_property_email') , 10, 1 );
add_action( 'transition_post_status', [ __CLASS__, 'send_email_when_publish_property' ], 10, 3 );
add_action( 'opalestate_processed_approve_publish_property', [ __CLASS__, 'approve_publish_property_email' ], 10, 1 );
}
/**
* Send email when User contact via Enquiry Form and Contact Form
*/
add_action( 'opalestate_send_email_notifycation', array(__CLASS__,'send_notifycation') );
add_action( 'opalestate_send_email_submitted', array(__CLASS__,'new_submission_email') );
add_action( 'opalestate_send_email_request_reviewing', array( __CLASS__, 'send_email_request_reviewing') );
add_action( 'opalestate_send_email_notifycation', [ __CLASS__, 'send_notifycation' ] );
add_action( 'opalestate_send_email_submitted', [ __CLASS__, 'new_submission_email' ] );
add_action( 'opalestate_send_email_request_reviewing', [ __CLASS__, 'send_email_request_reviewing' ] );
}
/**
@ -67,57 +69,51 @@ class Opalestate_Emails {
/**
* Send Email Notifycation with two types: Enquiry or Contact
*/
public static function send_notifycation ( $content ) {
$mail = new OpalEstate_Send_Email_Notification() ;
$mail->set_args ( $content );
public static function send_notifycation( $content ) {
$mail = new OpalEstate_Send_Email_Notification();
$mail->set_args( $content );
$return = self::send_mail_now( $mail );
if( isset($content['data']) ){
if ( isset( $content['data'] ) ) {
$return['data'] = $content['data'];
}
echo json_encode( $return ); die();
}
echo json_encode( $return );
die();
}
/**
* send email if agent submit a new property
*/
public static function new_submission_email( $user_id, $post_id ){
$mail = new OpalEstate_Send_Email_New_Submitted() ;
public static function new_submission_email( $user_id, $post_id ) {
$mail = new OpalEstate_Send_Email_New_Submitted();
$mail->set_pros( $post_id, $user_id );
$return = self::send_mail_now( $mail );
echo json_encode( $return ); die();
echo json_encode( $return );
die();
}
/**
* Send email to requet viewing a property
*/
public static function send_email_request_reviewing( $content ){
public static function send_email_request_reviewing( $content ) {
$mail = new OpalEstate_Send_Email_Request_Reviewing();
$mail->set_args( $content );
$return = self::send_mail_now( $mail );
echo json_encode( $return ); die();
echo json_encode( $return );
die();
}
/**
*
*/
public static function send_mail_now( $mail ){
public static function send_mail_now( $mail ) {
$from_name = $mail->from_name();
$from_email = $mail->from_email();
$headers = sprintf( "From: %s <%s>\r\n Content-type: text/html", $from_name, $from_email );
@ -125,20 +121,22 @@ class Opalestate_Emails {
$subject = $mail->get_subject();
$message = $mail->get_body();
if( $mail->to_email() ) {
if ( $mail->to_email() ) {
if( $mail->get_cc() ){
if ( $mail->get_cc() ) {
$status = @wp_mail( $mail->get_cc(), $subject, $message, $headers );
}
$status = @wp_mail( $mail->to_email(), $subject, $message, $headers );
$return = array( 'status' => true, 'msg' => esc_html__( 'Message has been successfully sent.', 'opalestate-pro' ) );
if ( $status ) {
return [ 'status' => true, 'msg' => esc_html__( 'Message has been successfully sent.', 'opalestate-pro' ) ];
} else {
$return = array( 'status' => true, 'msg' => esc_html__( 'Message has been successfully sent.', 'opalestate-pro' ) );
return [ 'status' => true, 'msg' => esc_html__( 'Unable to send a message.', 'opalestate-pro' ) ];
}
}
return $return;
return [ 'status' => true, 'msg' => esc_html__( 'Missing some information!', 'opalestate-pro' ) ];
}
/**
@ -146,11 +144,11 @@ class Opalestate_Emails {
*/
public static function send_email_when_publish_property( $new_status, $old_status, $post ) {
if( is_object( $post ) ){
if ( is_object( $post ) ) {
if ( $post->post_type == 'opalestate_property' ) {
if ( $new_status != $old_status ) {
if ($new_status == 'publish' ) {
if ($old_status == 'draft' || $old_status == 'pending') {
if ( $new_status == 'publish' ) {
if ( $old_status == 'draft' || $old_status == 'pending' ) {
// Send email
$post_id = $post->ID;
do_action( "opalestate_processed_approve_publish_property", $post_id );
@ -165,24 +163,25 @@ class Opalestate_Emails {
/**
* add new tab Email in opalestate -> setting
*/
public static function setting_email_tab( $tabs ){
public static function setting_email_tab( $tabs ) {
$tabs['emails'] = esc_html__( 'Email', 'opalestate-pro' );
return $tabs;
}
public static function newproperty_email_body(){
public static function newproperty_email_body() {
}
public static function approve_email_body(){
public static function approve_email_body() {
}
/**
* render setting email fields with default values
*/
public static function setting_email_fields( $fields ){
public static function setting_email_fields( $fields ) {
$contact_list_tags = '<div>
<p class="tags-description">Use the following tags to automatically add property information to the emails. Tags labeled with an asterisk (*) can be used in the email subject as well.</p>
@ -253,135 +252,135 @@ class Opalestate_Emails {
$list_tags = apply_filters( 'opalestate_email_tags', $list_tags );
$fields = array(
$fields = [
'id' => 'options_page',
'title' => esc_html__( 'Email Settings', 'opalestate-pro' ),
'show_on' => array( 'key' => 'options-page', 'value' => array( 'opalestate_settings' ), ),
'fields' => apply_filters( 'opalestate_settings_emails', array(
array(
'show_on' => [ 'key' => 'options-page', 'value' => [ 'opalestate_settings' ], ],
'fields' => apply_filters( 'opalestate_settings_emails', [
[
'name' => esc_html__( 'Email Settings', 'opalestate-pro' ),
'desc' => '<hr>',
'id' => 'opalestate_title_email_settings_1',
'type' => 'title'
),
array(
'type' => 'title',
],
[
'id' => 'from_name',
'name' => esc_html__( 'From Name', 'opalestate-pro' ),
'desc' => esc_html__( 'The name donation receipts are said to come from. This should probably be your site or shop name.', 'opalestate-pro' ),
'default' => get_bloginfo( 'name' ),
'type' => 'text'
),
array(
'type' => 'text',
],
[
'id' => 'from_email',
'name' => esc_html__( 'From Email', 'opalestate-pro' ),
'desc' => esc_html__( 'Email to send donation receipts from. This will act as the "from" and "reply-to" address.', 'opalestate-pro' ),
'default' => get_bloginfo( 'admin_email' ),
'type' => 'text'
),
'type' => 'text',
],
array(
[
'name' => esc_html__( 'Email Submission Templates (Template Tags)', 'opalestate-pro' ),
'desc' => $list_tags.'<br><hr>',
'desc' => $list_tags . '<br><hr>',
'id' => 'opalestate_title_email_settings_2',
'type' => 'title'
),
'type' => 'title',
],
array(
[
'name' => esc_html__( 'Notification For New Property Submission', 'opalestate-pro' ),
'desc' => '<hr>',
'id' => 'opalestate_title_email_settings_3',
'type' => 'title'
),
'type' => 'title',
],
array(
[
'id' => 'newproperty_email_subject',
'name' => esc_html__( 'Email Subject', 'opalestate-pro' ),
'type' => 'text',
'desc' => esc_html__( 'The email subject for admin notifications.', 'opalestate-pro' ),
'attributes' => array(
'attributes' => [
'placeholder' => 'Your package is expired',
'rows' => 3,
),
'default' => esc_html__( 'New Property Listing Submitted: {property_name}', 'opalestate-pro' )
],
'default' => esc_html__( 'New Property Listing Submitted: {property_name}', 'opalestate-pro' ),
),
array(
],
[
'id' => 'newproperty_email_body',
'name' => esc_html__( 'Email Body', 'opalestate-pro' ),
'type' => 'wysiwyg',
'desc' => esc_html__( 'Enter the email an admin should receive when an initial payment request is made.', 'opalestate-pro' ),
'default' => OpalEstate_Send_Email_New_Submitted::get_default_template(),
),
],
//------------------------------------------
array(
[
'name' => esc_html__( 'Approve property for publish', 'opalestate-pro' ),
'desc' => '<hr>',
'id' => 'opalestate_title_email_settings_4',
'type' => 'title'
),
'type' => 'title',
],
array(
[
'name' => esc_html__( 'Enable approve property email', 'opalestate-pro' ),
'desc' => esc_html__( 'Enable approve property email.', 'opalestate-pro' ),
'id' => 'enable_approve_property_email',
'type' => 'switch',
'options' => array(
'options' => [
'on' => esc_html__( 'Enable', 'opalestate-pro' ),
'off' => esc_html__( 'Disable', 'opalestate-pro' ),
),
],
'default' => 'off',
),
],
array(
[
'id' => 'approve_email_subject',
'name' => esc_html__( 'Email Subject', 'opalestate-pro' ),
'type' => 'text',
'desc' => esc_html__( 'The email subject a user should receive when they make an initial property request.', 'opalestate-pro' ),
'attributes' => array(
'placeholder' => 'Your property at I Love WordPress is pending',get_bloginfo( 'name' ),
'attributes' => [
'placeholder' => 'Your property at I Love WordPress is pending',
get_bloginfo( 'name' ),
'rows' => 3,
),
'default' => esc_html__( 'New Property Listing Submitted: {property_name}', 'opalestate-pro' )
),
],
'default' => esc_html__( 'New Property Listing Submitted: {property_name}', 'opalestate-pro' ),
],
array(
[
'id' => 'approve_email_body',
'name' => esc_html__( 'Email Body', 'opalestate-pro' ),
'type' => 'wysiwyg',
'desc' => esc_html__( 'Enter the email a user should receive when they make an initial payment request.', 'opalestate-pro' ),
'default' => OpalEstate_Send_Email_Approve::get_default_template(),
),
],
/// email contact template ////
array(
[
'name' => esc_html__( 'Email Contact Templates (Template Tags)', 'opalestate-pro' ),
'desc' => $contact_list_tags.'<br><hr>',
'desc' => $contact_list_tags . '<br><hr>',
'id' => 'opalestate_title_email_settings_6',
'type' => 'title'
),
'type' => 'title',
],
array(
[
'id' => 'contact_email_subject',
'name' => esc_html__( 'Email Subject', 'opalestate-pro' ),
'type' => 'text',
'desc' => esc_html__( 'The email subject a user should receive when they make an initial property request.', 'opalestate-pro' ),
'attributes' => array(
'placeholder' => 'Your property at I Love WordPress is pending',get_bloginfo( 'name' ),
'attributes' => [
'placeholder' => 'Your property at I Love WordPress is pending',
get_bloginfo( 'name' ),
'rows' => 3,
),
'default' => esc_html__('You got a message', 'opalestate-pro')
),
],
'default' => esc_html__( 'You got a message', 'opalestate-pro' ),
],
array(
[
'id' => 'contact_email_body',
'name' => esc_html__( 'Email Body', 'opalestate-pro' ),
'type' => 'wysiwyg',
'desc' => trim(preg_replace('/\t+/', '', "Hi {receive_name},<br>
'desc' => trim( preg_replace( '/\t+/', '', "Hi {receive_name},<br>
You have got message from {name} with email {email}. Here is detail:
<br>
<br>
@ -389,11 +388,11 @@ class Opalestate_Emails {
<br>
&nbsp;<br>
<br>
<em>This message was sent by {site_link} on {current_time}.</em>"))
)
)
)
);
<em>This message was sent by {site_link} on {current_time}.</em>" ) ),
],
]
),
];
return $fields;
}
@ -401,12 +400,12 @@ class Opalestate_Emails {
/**
* get data of newrequest email
*
* @var $args array: property_id , $body
* @return text: message
* @var $args array: property_id , $body
*/
public static function replace_shortcode( $args, $body ) {
$tags = array(
$tags = [
'user_name' => "",
'user_mail' => "",
'submitted_date' => "",
@ -414,31 +413,34 @@ class Opalestate_Emails {
'site_name' => '',
'site_link' => '',
'property_link' => '',
);
];
$tags = array_merge( $tags, $args );
extract( $tags );
$tags = array( "{user_mail}",
$tags = [
"{user_mail}",
"{user_name}",
"{submitted_date}",
"{site_name}",
"{site_link}",
"{current_time}",
'{property_name}',
'{property_link}');
'{property_link}',
];
$values = array( $user_mail,
$user_name ,
$submitted_date ,
get_bloginfo( 'name' ) ,
$values = [
$user_mail,
$user_name,
$submitted_date,
get_bloginfo( 'name' ),
get_home_url(),
date("F j, Y, g:i a"),
date( "F j, Y, g:i a" ),
$property_name,
$property_link
);
$property_link,
];
$message = str_replace($tags, $values, $body);
$message = str_replace( $tags, $values, $body );
return $message;
}
@ -450,7 +452,8 @@ class Opalestate_Emails {
$return = self::send_mail_now( $mail );
echo json_encode( $return ); die();
echo json_encode( $return );
die();
}
}

View File

@ -23,7 +23,7 @@ if ( ! defined( 'ABSPATH' ) ) {
*/
class OpalEstate_Abstract_Email_Template {
public $args = array();
public $args = [];
/**
* Get the unique email notification key.
@ -53,7 +53,7 @@ class OpalEstate_Abstract_Email_Template {
return esc_html__( 'Send notices to the site administrator before a job listing expires.', 'opalestate-pro' );
}
public function to_email () {
public function to_email() {
}
@ -62,32 +62,31 @@ class OpalEstate_Abstract_Email_Template {
}
public function set_args ( $args ) {
public function set_args( $args ) {
return $this->args = $args;
}
public function replace_tags ( $template ) {
public function replace_tags( $template ) {
$args = $this->args;
$default = array(
$default = [
'receiver_name' => '',
'name' => '',
'receiver_email' => '',
'property_link' => '',
'message' => '',
'site_name' => bloginfo(),
'site_name' => get_bloginfo(),
'site_link' => get_home_url(),
'current_time' => date("F j, Y, g:i a"),
'phone' => ''
);
'current_time' => date( "F j, Y, g:i a" ),
'phone' => '',
];
$args = array_merge( $default, $args );
$tags = array();
$values = array() ;
$tags = [];
$values = [];
foreach ( $args as $key => $value ) {
$tags[] = "{".$key."}";
$tags[] = "{" . $key . "}";
$values[] = $value;
}
@ -96,16 +95,16 @@ class OpalEstate_Abstract_Email_Template {
return $message;
}
public function get_subject () {
public function get_subject() {
}
public function from_email() {
return opalestate_get_option( 'from_email' , get_bloginfo( 'admin_email' ) );
return opalestate_get_option( 'from_email', get_bloginfo( 'admin_email' ) );
}
public function from_name() {
return opalestate_get_option('from_name', get_bloginfo( 'name' ) );
return opalestate_get_option( 'from_name', get_bloginfo( 'name' ) );
}
public function get_cc() {
@ -113,13 +112,13 @@ class OpalEstate_Abstract_Email_Template {
}
public function get_body(){
public function get_body() {
$template = $this->get_content_template();
return $this->replace_tags( $template );
}
public function get_plain_text_body () {
public function get_plain_text_body() {
}
}

View File

@ -26,8 +26,9 @@ class OpalEstate_Send_Email_Request_Reviewing extends OpalEstate_Abstract_Email_
/**
* Send Email
*/
public function get_subject () {
$propety_title = '' ;
public function get_subject() {
$propety_title = '';
return sprintf( esc_html__( 'You have a message request reviewing: %s at', 'opalestate-pro' ), $propety_title );
}
@ -41,14 +42,14 @@ class OpalEstate_Send_Email_Request_Reviewing extends OpalEstate_Abstract_Email_
/**
* Send Email
*/
public function to_email () {
public function to_email() {
return $this->args ['receiver_email'];
}
/**
* Send Email
*/
public function cc_email () {
public function cc_email() {
return $this->args ['sender_email'];
}
@ -56,15 +57,12 @@ class OpalEstate_Send_Email_Request_Reviewing extends OpalEstate_Abstract_Email_
* Send Email
*/
public function get_body() {
$post = get_post( $this->args['post_id'] );
$this->args['email'] = $this->args['receiver_email'];
$this->args['property_link'] = get_permalink( $post->ID );
$this->args['property_name'] = $post->post_title;
return parent::get_body();
}
}
?>

View File

@ -99,13 +99,13 @@ class OpalEstate_User_Message {
$post['property_link'] = (int) $post['post_id'] ? get_permalink( $post['post_id'] ) : get_home_url();
$post['receive_name'] = $member['name'];
$post['receive_name'] = isset( $member['name'] ) ? $member['name'] : '';
$subject = html_entity_decode( esc_html__( 'You got a message', 'opalestate-pro' ) );
$post['receiver_name'] = $member['receiver_name'];
$output = [
'subject' => $subject,
'name' => $member['name'],
'name' => isset( $member['name'] ) ? $member['name'] : '',
'receiver_email' => $member['receiver_email'],
'receiver_id' => $member['receiver_id'],
'sender_id' => get_current_user_id(),
@ -241,20 +241,16 @@ class OpalEstate_User_Message {
}
/**
*
* Process send email.
*/
public function process_send_email() {
do_action( 'opalestate_process_send_email_before' );
if ( isset( $_POST['type'] ) && $_POST['type'] ) {
$content = [];
switch ( trim( $_POST['type'] ) ) {
case 'send_equiry':
if ( wp_verify_nonce( $_POST['message_action'], 'send-enquiry-form' ) ) {
$member = $this->get_member_email_data( (int) $_POST['post_id'] );
$content = $this->send_equiry( $_POST, $member );
}
@ -269,8 +265,6 @@ class OpalEstate_User_Message {
}
if ( $content ) {
// only save in db for user only
if ( $content['receiver_id'] > 0 && $this->is_log ) {
$this->insert( $content );

View File

@ -1,7 +1,7 @@
<?php
global $post;
$message = sprintf(__('Hi, I am interested in %s (Property ID: %s)', 'opalestate-pro'), get_the_title() , get_the_ID() );
$message = sprintf( __( 'Hi, I am interested in %s (Property ID: %s)', 'opalestate-pro' ), get_the_title(), get_the_ID() );
$property_id = get_the_ID();
$heading = esc_html__( 'Enquire about property', 'opalestate-pro' );
@ -12,34 +12,35 @@ $form = OpalEstate()->html->render_form( $fields );
$id = 'send-enquiry-form';
?>
<?php if( isset($nowrap) && $nowrap ) : ?>
<?php if ( isset( $nowrap ) && $nowrap ) : ?>
<form method="post" class="opalestate-message-form">
<?php do_action('opalestate_message_form_before'); ?>
<?php do_action( 'opalestate_message_form_before' ); ?>
<?php echo $form;?>
<?php echo $form; ?>
<?php do_action( 'opalestate_message_form_after' ); ?>
<?php wp_nonce_field( $id, 'message_action' ); ?>
<button class="button btn btn-primary btn-3d" data-loading-text="<i class='fa fa-circle-o-notch fa-spin'></i> <?php esc_html_e( ' Processing', 'opalestate-pro' ); ?>" type="submit" name="contact-form"><?php echo esc_html__( 'Send message', 'opalestate-pro' ); ?></button>
</form>
<button class="button btn btn-primary btn-3d" data-loading-text="<i class='fa fa-circle-o-notch fa-spin'></i> <?php esc_html_e( ' Processing', 'opalestate-pro' ); ?>" type="submit"
name="contact-form"><?php echo esc_html__( 'Send message', 'opalestate-pro' ); ?></button>
</form>
<?php else : ?>
<div class="opalestate-box-content property-equire-form">
<div class="opalestate-box-content property-equire-form">
<div class="opalestate-box">
<div class="property-equire-form-container">
<h5 class="contact-form-title"><?php echo $heading; ?></h5>
<div class="box-content">
<form method="post" class="opalestate-message-form">
<?php do_action('opalestate_message_form_before'); ?>
<?php do_action( 'opalestate_message_form_before' ); ?>
<?php echo $form;?>
<?php echo $form; ?>
<?php do_action( 'opalestate_message_form_after' ); ?>
<?php wp_nonce_field( $id, 'message_action' ); ?>
<button class="button btn btn-primary btn-3d" data-loading-text="<i class='fa fa-circle-o-notch fa-spin'></i> <?php esc_html_e( ' Processing', 'opalestate-pro' ); ?>" type="submit" name="contact-form"><?php echo esc_html__( 'Send message', 'opalestate-pro' ); ?></button>
<button class="button btn btn-primary btn-3d" data-loading-text="<i class='fa fa-circle-o-notch fa-spin'></i> <?php esc_html_e( ' Processing', 'opalestate-pro' ); ?>"
type="submit" name="contact-form"><?php echo esc_html__( 'Send message', 'opalestate-pro' ); ?></button>
</form>
</div><!-- /.agent-contact-form -->
</div><!-- /.agent-contact-->
</div>
</div>
</div>
<?php endif; ?>