Email Verification when change email
This commit is contained in:
parent
da985f27e1
commit
0d966a5e03
@ -96,7 +96,7 @@ class Message
|
|||||||
|
|
||||||
public static function sendEmail($to, $subject, $body)
|
public static function sendEmail($to, $subject, $body)
|
||||||
{
|
{
|
||||||
global $config, $PAGES_PATH, $_app_stage;
|
global $config, $PAGES_PATH, $debug_mail;
|
||||||
if (empty($body)) {
|
if (empty($body)) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
@ -116,7 +116,7 @@ class Message
|
|||||||
} else {
|
} else {
|
||||||
$mail = new PHPMailer();
|
$mail = new PHPMailer();
|
||||||
$mail->isSMTP();
|
$mail->isSMTP();
|
||||||
if ($_app_stage == 'Dev') {
|
if (isset($debug_mail) && $debug_mail == 'Dev') {
|
||||||
$mail->SMTPDebug = SMTP::DEBUG_SERVER;
|
$mail->SMTPDebug = SMTP::DEBUG_SERVER;
|
||||||
}
|
}
|
||||||
$mail->Host = $config['smtp_host'];
|
$mail->Host = $config['smtp_host'];
|
||||||
|
@ -67,16 +67,9 @@ switch ($action) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'profile':
|
case 'profile':
|
||||||
$d = ORM::for_table('tbl_customers')->find_one($user['id']);
|
|
||||||
if ($d) {
|
|
||||||
run_hook('customer_view_edit_profile'); #HOOK
|
run_hook('customer_view_edit_profile'); #HOOK
|
||||||
$ui->assign('d', $d);
|
|
||||||
$ui->display('user-ui/profile.tpl');
|
$ui->display('user-ui/profile.tpl');
|
||||||
} else {
|
|
||||||
r2(U . 'home', 'e', Lang::T('Account Not Found'));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'edit-profile-post':
|
case 'edit-profile-post':
|
||||||
$fullname = _post('fullname');
|
$fullname = _post('fullname');
|
||||||
$address = _post('address');
|
$address = _post('address');
|
||||||
@ -84,45 +77,32 @@ switch ($action) {
|
|||||||
$phonenumber = _post('phonenumber');
|
$phonenumber = _post('phonenumber');
|
||||||
run_hook('customer_edit_profile'); #HOOK
|
run_hook('customer_edit_profile'); #HOOK
|
||||||
$msg = '';
|
$msg = '';
|
||||||
if (Validator::Length($fullname, 31, 2) == false) {
|
if (Validator::Length($fullname, 31, 1) == false) {
|
||||||
$msg .= 'Full Name should be between 3 to 30 characters' . '<br>';
|
$msg .= 'Full Name should be between 1 to 30 characters' . '<br>';
|
||||||
}
|
}
|
||||||
if (Validator::UnsignedNumber($phonenumber) == false) {
|
if (Validator::UnsignedNumber($phonenumber) == false) {
|
||||||
$msg .= 'Phone Number must be a number' . '<br>';
|
$msg .= 'Phone Number must be a number' . '<br>';
|
||||||
}
|
}
|
||||||
|
|
||||||
$d = ORM::for_table('tbl_customers')->find_one($user['id']);
|
$user->fullname = $fullname;
|
||||||
if ($d) {
|
$user->address = $address;
|
||||||
} else {
|
if ($_c['allow_phone_otp'] != 'yes') {
|
||||||
$msg .= Lang::T('Data Not Found') . '<br>';
|
$user->phonenumber = $phonenumber;
|
||||||
|
}
|
||||||
|
if ($_c['allow_email_otp'] != 'yes') {
|
||||||
|
$user->email = $email;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($msg == '') {
|
$user->save();
|
||||||
$d->fullname = $fullname;
|
|
||||||
$d->address = $address;
|
|
||||||
$d->email = $email;
|
|
||||||
$d->phonenumber = $phonenumber;
|
|
||||||
$d->save();
|
|
||||||
|
|
||||||
_log('[' . $user['username'] . ']: ' . Lang::T('User Updated Successfully'), 'User', $user['id']);
|
_log('[' . $user['username'] . ']: ' . Lang::T('User Updated Successfully'), 'User', $user['id']);
|
||||||
r2(U . 'accounts/profile', 's', Lang::T('User Updated Successfully'));
|
r2(U . 'accounts/profile', 's', Lang::T('User Updated Successfully'));
|
||||||
} else {
|
|
||||||
r2(U . 'accounts/profile', 'e', $msg);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
case 'phone-update':
|
case 'phone-update':
|
||||||
|
|
||||||
$d = ORM::for_table('tbl_customers')->find_one($user['id']);
|
|
||||||
if ($d) {
|
|
||||||
//run_hook('customer_view_edit_profile'); #HOOK
|
|
||||||
$ui->assign('d', $d);
|
|
||||||
$ui->assign('new_phone', $_SESSION['new_phone']);
|
$ui->assign('new_phone', $_SESSION['new_phone']);
|
||||||
$ui->display('user-ui/phone-update.tpl');
|
$ui->display('user-ui/phone-update.tpl');
|
||||||
} else {
|
|
||||||
r2(U . 'home', 'e', Lang::T('Account Not Found'));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'phone-update-otp':
|
case 'phone-update-otp':
|
||||||
@ -131,7 +111,7 @@ switch ($action) {
|
|||||||
$otpPath = $CACHE_PATH . '/sms/';
|
$otpPath = $CACHE_PATH . '/sms/';
|
||||||
$_SESSION['new_phone'] = $phone;
|
$_SESSION['new_phone'] = $phone;
|
||||||
// Validate the phone number format
|
// Validate the phone number format
|
||||||
if (!preg_match('/^[0-9]{10,}$/', $phone)) {
|
if (!preg_match('/^[0-9]{10,}$/', $phone) || empty($phone)) {
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('Invalid phone number format'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('Invalid phone number format'));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -139,11 +119,9 @@ switch ($action) {
|
|||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('SMS server not Available, Please try again later'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('SMS server not Available, Please try again later'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($config['sms_url'])) {
|
$d = ORM::for_table('tbl_customers')->whereNotEqual('username', $username)->where('phonenumber', $phone)->find_one();
|
||||||
if (!empty($phone)) {
|
|
||||||
$d = ORM::for_table('tbl_customers')->where('username', $username)->where('phonenumber', $phone)->find_one();
|
|
||||||
if ($d) {
|
if ($d) {
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('You cannot use your current phone number'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('Phone number already registered by another customer'));
|
||||||
}
|
}
|
||||||
if (!file_exists($otpPath)) {
|
if (!file_exists($otpPath)) {
|
||||||
mkdir($otpPath);
|
mkdir($otpPath);
|
||||||
@ -154,7 +132,7 @@ switch ($action) {
|
|||||||
|
|
||||||
// expired 10 minutes
|
// expired 10 minutes
|
||||||
if (file_exists($otpFile) && time() - filemtime($otpFile) < 600) {
|
if (file_exists($otpFile) && time() - filemtime($otpFile) < 600) {
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('Please wait ' . (600 - (time() - filemtime($otpFile))) . ' seconds before sending another SMS'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('Please wait ') . (600 - (time() - filemtime($otpFile))) . Lang::T(' seconds before sending another SMS'));
|
||||||
} else {
|
} else {
|
||||||
$otp = rand(100000, 999999);
|
$otp = rand(100000, 999999);
|
||||||
file_put_contents($otpFile, $otp);
|
file_put_contents($otpFile, $otp);
|
||||||
@ -171,8 +149,6 @@ switch ($action) {
|
|||||||
//redirect after sending OTP
|
//redirect after sending OTP
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('Verification code has been sent to your phone'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('Verification code has been sent to your phone'));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -185,10 +161,12 @@ switch ($action) {
|
|||||||
// Validate the phone number format
|
// Validate the phone number format
|
||||||
if (!preg_match('/^[0-9]{10,}$/', $phone)) {
|
if (!preg_match('/^[0-9]{10,}$/', $phone)) {
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('Invalid phone number format'));
|
r2(U . 'accounts/phone-update', 'e', Lang::T('Invalid phone number format'));
|
||||||
exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($config['sms_url'])) {
|
if (empty($config['sms_url'])) {
|
||||||
|
r2(U . 'accounts/phone-update', 'e', Lang::T('SMS server not Available, Please try again later'));
|
||||||
|
}
|
||||||
|
|
||||||
$otpFile = $otpPath . sha1($username . $db_pass) . ".txt";
|
$otpFile = $otpPath . sha1($username . $db_pass) . ".txt";
|
||||||
$phoneFile = $otpPath . sha1($username . $db_pass) . "_phone.txt";
|
$phoneFile = $otpPath . sha1($username . $db_pass) . "_phone.txt";
|
||||||
|
|
||||||
@ -224,19 +202,114 @@ switch ($action) {
|
|||||||
unlink($otpFile);
|
unlink($otpFile);
|
||||||
unlink($phoneFile);
|
unlink($phoneFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update the phone number in the database
|
||||||
|
$user->phonenumber = Lang::phoneFormat($phone);
|
||||||
|
$user->save();
|
||||||
|
|
||||||
|
r2(U . 'accounts/profile', 's', Lang::T('Phone number updated successfully'));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'email-update':
|
||||||
|
$ui->assign('new_email', $_SESSION['new_email']);
|
||||||
|
$ui->display('user-ui/email-update.tpl');
|
||||||
|
break;
|
||||||
|
case 'email-update-otp':
|
||||||
|
$email = trim(_post('email'));
|
||||||
|
$username = $user['username'];
|
||||||
|
$otpPath = $CACHE_PATH . '/email/';
|
||||||
|
$_SESSION['new_email'] = $email;
|
||||||
|
// Validate the phone number format
|
||||||
|
if (!Validator::Email($email)) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Invalid Email address format'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($config['smtp_host'])) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Email server not Available, Please ask admin to configure it'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$d = ORM::for_table('tbl_customers')->whereNotEqual('username', $username)->where('email', $email)->find_one();
|
||||||
|
if ($d) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Email already used by another Customer'));
|
||||||
|
}
|
||||||
|
if (!file_exists($otpPath)) {
|
||||||
|
mkdir($otpPath);
|
||||||
|
touch($otpPath . 'index.html');
|
||||||
|
}
|
||||||
|
$otpFile = $otpPath . sha1($username . $db_pass) . ".txt";
|
||||||
|
$emailFile = $otpPath . sha1($username . $db_pass) . "_email.txt";
|
||||||
|
|
||||||
|
// expired 10 minutes
|
||||||
|
if (file_exists($otpFile) && time() - filemtime($otpFile) < 600) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Please wait ') . (600 - (time() - filemtime($otpFile))) . Lang::T(' seconds before sending another Email'));
|
||||||
} else {
|
} else {
|
||||||
r2(U . 'accounts/phone-update', 'e', Lang::T('SMS server not available'));
|
$otp = rand(100000, 999999);
|
||||||
|
file_put_contents($otpFile, $otp);
|
||||||
|
file_put_contents($emailFile, $email);
|
||||||
|
// send OTP to user
|
||||||
|
$body = Lang::T("Hello") . ' ' . $user['fullname'] . ",\n\n" . Lang::T("Your Email Verification Code is:") . " $otp";
|
||||||
|
Message::sendEmail($email, Lang::T('Change Email Verification Code'), $body);
|
||||||
|
//redirect after sending OTP
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Verification code has been sent to your email. Check Spam folder if not found.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'email-update-post':
|
||||||
|
$email = trim(_post('email'));
|
||||||
|
$otp_code = _post('otp');
|
||||||
|
$username = $user['username'];
|
||||||
|
$otpPath = $CACHE_PATH . '/email/';
|
||||||
|
// Validate the phone number format
|
||||||
|
if (!Validator::Email($email)) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Invalid Email address format'));
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update the phone number in the database
|
if (empty($config['smtp_host'])) {
|
||||||
$d = ORM::for_table('tbl_customers')->where('username', $username)->find_one();
|
r2(U . 'accounts/email-update', 'e', Lang::T('Email server not Available, Please ask admin to configure it'));
|
||||||
if ($d) {
|
|
||||||
$d->phonenumber = Lang::phoneFormat($phone);
|
|
||||||
$d->save();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r2(U . 'accounts/profile', 's', Lang::T('Phone number updated successfully'));
|
$otpFile = $otpPath . sha1($username . $db_pass) . ".txt";
|
||||||
|
$emailFile = $otpPath . sha1($username . $db_pass) . "_email.txt";
|
||||||
|
|
||||||
|
// Check if OTP file exists
|
||||||
|
if (!file_exists($otpFile)) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Please request OTP first'));
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
// expired 10 minutes
|
||||||
|
if (time() - filemtime($otpFile) > 1200) {
|
||||||
|
unlink($otpFile);
|
||||||
|
unlink($emailFile);
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Verification code expired'));
|
||||||
|
exit();
|
||||||
|
} else {
|
||||||
|
$code = file_get_contents($otpFile);
|
||||||
|
|
||||||
|
// Check if OTP code matches
|
||||||
|
if ($code != $otp_code) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('Wrong Verification code'));
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the phone number matches the one that requested the OTP
|
||||||
|
$savedEmail = file_get_contents($emailFile);
|
||||||
|
if ($savedEmail !== $email) {
|
||||||
|
r2(U . 'accounts/email-update', 'e', Lang::T('The Email Address does not match the one that requested the OTP'));
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OTP verification successful, delete OTP and phone number files
|
||||||
|
unlink($otpFile);
|
||||||
|
unlink($emailFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
$user->email = $email;
|
||||||
|
$user->save();
|
||||||
|
|
||||||
|
r2(U . 'accounts/profile', 's', Lang::T('Email Address updated successfully'));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'language-update-post':
|
case 'language-update-post':
|
||||||
|
@ -22,7 +22,7 @@ switch ($do) {
|
|||||||
$password = _post('password');
|
$password = _post('password');
|
||||||
$cpassword = _post('cpassword');
|
$cpassword = _post('cpassword');
|
||||||
$address = _post('address');
|
$address = _post('address');
|
||||||
if (!empty($config['sms_url'])) {
|
if (!empty($config['sms_url']) && $_c['allow_phone_otp'] == 'yes') {
|
||||||
$phonenumber = Lang::phoneFormat($username);
|
$phonenumber = Lang::phoneFormat($username);
|
||||||
$username = $phonenumber;
|
$username = $phonenumber;
|
||||||
} else if (strlen($username) < 21) {
|
} else if (strlen($username) < 21) {
|
||||||
@ -45,7 +45,7 @@ switch ($do) {
|
|||||||
$msg .= Lang::T('Passwords does not match') . '<br>';
|
$msg .= Lang::T('Passwords does not match') . '<br>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($config['sms_url'])) {
|
if (!empty($config['sms_url']) && $_c['allow_phone_otp'] == 'yes') {
|
||||||
$otpPath .= sha1($username . $db_pass) . ".txt";
|
$otpPath .= sha1($username . $db_pass) . ".txt";
|
||||||
run_hook('validate_otp'); #HOOK
|
run_hook('validate_otp'); #HOOK
|
||||||
//expired 10 minutes
|
//expired 10 minutes
|
||||||
@ -111,7 +111,7 @@ switch ($do) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (!empty($config['sms_url'])) {
|
if (!empty($config['sms_url']) && $_c['allow_phone_otp'] == 'yes') {
|
||||||
$username = _post('username');
|
$username = _post('username');
|
||||||
if (!empty($username)) {
|
if (!empty($username)) {
|
||||||
$d = ORM::for_table('tbl_customers')->where('username', $username)->find_one();
|
$d = ORM::for_table('tbl_customers')->where('username', $username)->find_one();
|
||||||
|
@ -626,7 +626,7 @@
|
|||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">{Lang::T('OTP Required')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Phone OTP Required')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<select name="allow_phone_otp" id="allow_phone_otp" class="form-control">
|
<select name="allow_phone_otp" id="allow_phone_otp" class="form-control">
|
||||||
<option value="no" {if $_c['allow_phone_otp']=='no' }selected="selected" {/if}>
|
<option value="no" {if $_c['allow_phone_otp']=='no' }selected="selected" {/if}>
|
||||||
@ -636,7 +636,7 @@
|
|||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">
|
<p class="help-block col-md-4">
|
||||||
{Lang::T('OTP is required when user want to change phone number')}
|
{Lang::T('OTP is required when user want to change phone number and registration')}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
@ -654,6 +654,20 @@
|
|||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">{Lang::T('The method which OTP will be sent to user')}</p>
|
<p class="help-block col-md-4">{Lang::T('The method which OTP will be sent to user')}</p>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label">{Lang::T('Email OTP Required')}</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<select name="allow_email_otp" id="allow_email_otp" class="form-control">
|
||||||
|
<option value="no" {if $_c['allow_email_otp']=='no' }selected="selected" {/if}>
|
||||||
|
No</option>
|
||||||
|
<option value="yes" {if $_c['allow_email_otp']=='yes' }selected="selected" {/if}>Yes
|
||||||
|
</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<p class="help-block col-md-4">
|
||||||
|
{Lang::T('OTP is required when user want to change Email Address')}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">{Lang::T('Extend Package Expiry')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Extend Package Expiry')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
|
79
ui/ui/user-ui/email-update.tpl
Normal file
79
ui/ui/user-ui/email-update.tpl
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
{include file="user-ui/header.tpl"}
|
||||||
|
|
||||||
|
<!-- user-phone-update -->
|
||||||
|
|
||||||
|
<div class="box box-danger">
|
||||||
|
<div class="box-header with-border">
|
||||||
|
<h3 class="box-title">{Lang::T('Change Email Address')}</h3>
|
||||||
|
</div>
|
||||||
|
<div class="box-body">
|
||||||
|
<div class="form-horizontal">
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label">{Lang::T('Current Email')}</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="input-group">
|
||||||
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
|
<input type="text" class="form-control" name="email"
|
||||||
|
value="{$_user['email']}" readonly placeholder="{Lang::T('Email')}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<form method="post" role="form" action="{$_url}accounts/email-update-otp">
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label">{Lang::T('New Email')}</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="input-group">
|
||||||
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
|
<input type="text" class="form-control" name="email" id="email" value="{$new_email}" required
|
||||||
|
placeholder="{Lang::T('Input your Email')}">
|
||||||
|
<span class="input-group-btn">
|
||||||
|
<button type="submit" class="btn btn-info btn-flat">{Lang::T('Request OTP')}</button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
<form method="post" role="form" action="{$_url}accounts/email-update-post">
|
||||||
|
<!-- Form 2 -->
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label">{Lang::T('OTP')}</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<input type="number" class="form-control" id="otp" name="otp"
|
||||||
|
placeholder="{Lang::T('Enter OTP that was sent to your email')}" required>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Hidden field to store the phone number value -->
|
||||||
|
<input type="hidden" name="email" id="hidden_email">
|
||||||
|
|
||||||
|
<center>
|
||||||
|
<button class="btn btn-success" type="submit"
|
||||||
|
onclick="return validateForm()">{Lang::T('Update')}</button>
|
||||||
|
Or <a href="{$_url}home">{Lang::T('Cancel')}</a>
|
||||||
|
</center>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
function validateForm() {
|
||||||
|
var email = document.getElementById("email").value;
|
||||||
|
var otp = document.getElementById("otp").value;
|
||||||
|
|
||||||
|
if (email.trim() === "") {
|
||||||
|
alert("Email Address is required.");
|
||||||
|
return false; // Prevent form submission
|
||||||
|
}
|
||||||
|
|
||||||
|
if (otp.trim() === "") {
|
||||||
|
alert("OTP code is required.");
|
||||||
|
return false; // Prevent form submission
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set the phone number value in the hidden field
|
||||||
|
document.getElementById("hidden_email").value = email;
|
||||||
|
return true; // Allow form submission
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{include file="user-ui/footer.tpl"}
|
@ -14,7 +14,7 @@
|
|||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<span class="input-group-addon" id="basic-addon1">+</span>
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
||||||
value="{$d['phonenumber']}" readonly placeholder="{Lang::T('Phone Number')}">
|
value="{$_user['phonenumber']}" readonly placeholder="{Lang::T('Phone Number')}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -8,14 +8,14 @@
|
|||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|
||||||
<form class="form-horizontal" method="post" role="form" action="{$_url}accounts/edit-profile-post">
|
<form class="form-horizontal" method="post" role="form" action="{$_url}accounts/edit-profile-post">
|
||||||
<input type="hidden" name="id" value="{$d['id']}">
|
<input type="hidden" name="id" value="{$_user['id']}">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">{Lang::T('Username')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Username')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<span class="input-group-addon" id="basic-addon1">+</span>
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
<input type="text" class="form-control" name="username" id="username" readonly
|
<input type="text" class="form-control" name="username" id="username" readonly
|
||||||
value="{$d['username']}"
|
value="{$_user['username']}"
|
||||||
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -24,14 +24,14 @@
|
|||||||
<label class="col-md-2 control-label">{Lang::T('Full Name')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Full Name')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<input type="text" class="form-control" id="fullname" name="fullname"
|
<input type="text" class="form-control" id="fullname" name="fullname"
|
||||||
value="{$d['fullname']}">
|
value="{$_user['fullname']}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">{Lang::T('Address')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Address')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<textarea name="address" id="address" class="form-control">{$d['address']}</textarea>
|
<textarea name="address" id="address" class="form-control">{$_user['address']}</textarea>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{if $_c['allow_phone_otp'] != 'yes'}
|
{if $_c['allow_phone_otp'] != 'yes'}
|
||||||
@ -41,7 +41,7 @@
|
|||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<span class="input-group-addon" id="basic-addon1">+</span>
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
||||||
value="{$d['phonenumber']}"
|
value="{$_user['phonenumber']}"
|
||||||
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -53,7 +53,7 @@
|
|||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<span class="input-group-addon" id="basic-addon1">+</span>
|
<span class="input-group-addon" id="basic-addon1">+</span>
|
||||||
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
<input type="text" class="form-control" name="phonenumber" id="phonenumber"
|
||||||
value="{$d['phonenumber']}" readonly
|
value="{$_user['phonenumber']}" readonly
|
||||||
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
placeholder="{if $_c['country_code_phone']!= ''}{$_c['country_code_phone']}{/if} {Lang::T('Phone Number')}">
|
||||||
<span class="input-group-btn">
|
<span class="input-group-btn">
|
||||||
<a href="{$_url}accounts/phone-update" type="button"
|
<a href="{$_url}accounts/phone-update" type="button"
|
||||||
@ -63,12 +63,30 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
|
{if $_c['allow_email_otp'] != 'yes'}
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">{Lang::T('Email')}</label>
|
<label class="col-md-2 control-label">{Lang::T('Email')}</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<input type="text" class="form-control" id="email" name="email" value="{$d['email']}">
|
<input type="text" class="form-control" id="email" name="email" value="{$_user['email']}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
{else}
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label">{Lang::T('Email Address')}</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="input-group">
|
||||||
|
<span class="input-group-addon"><i class="glyphicon glyphicon-envelope"></i></span>
|
||||||
|
<input type="text" class="form-control" name="email" id="email"
|
||||||
|
value="{$_user['email']}" readonly>
|
||||||
|
<span class="input-group-btn">
|
||||||
|
<a href="{$_url}accounts/email-update" type="button"
|
||||||
|
class="btn btn-info btn-flat">{Lang::T('Change')}</a>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-lg-offset-2 col-lg-10">
|
<div class="col-lg-offset-2 col-lg-10">
|
||||||
|
Loading…
x
Reference in New Issue
Block a user