Merge branch 'hotspotbilling:master' into master
This commit is contained in:
commit
b45f5a5587
11
CHANGELOG.md
11
CHANGELOG.md
@ -2,6 +2,17 @@
|
|||||||
|
|
||||||
# CHANGELOG
|
# CHANGELOG
|
||||||
|
|
||||||
|
## 2024.1.16
|
||||||
|
|
||||||
|
- Add yellow color to table for plan not allowed to purchase
|
||||||
|
- Fix Radius pool select
|
||||||
|
- add price to reminder notification
|
||||||
|
- Support thermal printer for invoice
|
||||||
|
|
||||||
|
## 2024.1.15
|
||||||
|
|
||||||
|
- Fix cron job for Plan only for admin by @Focuslinkstech
|
||||||
|
|
||||||
## 2024.1.11
|
## 2024.1.11
|
||||||
|
|
||||||
- Add Plan only for admin by @Focuslinkstech
|
- Add Plan only for admin by @Focuslinkstech
|
||||||
|
@ -99,4 +99,38 @@ class Lang
|
|||||||
}
|
}
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* $pad_type
|
||||||
|
* 0 Left
|
||||||
|
* 1 right
|
||||||
|
* 2 center
|
||||||
|
* */
|
||||||
|
public static function pad($text, $pad_string = ' ', $pad_type = 0){
|
||||||
|
global $config;
|
||||||
|
$cols = 37;
|
||||||
|
if($config['printer_cols']){
|
||||||
|
$cols = $config['printer_cols'];
|
||||||
|
}
|
||||||
|
$text = trim($text);
|
||||||
|
$texts = explode("\n", $text);
|
||||||
|
if(count($texts)>1){
|
||||||
|
$text = '';
|
||||||
|
foreach($texts as $t){
|
||||||
|
$text.= self::pad(trim($t), $pad_string, $pad_type)."\n";
|
||||||
|
}
|
||||||
|
return $text;
|
||||||
|
}else{
|
||||||
|
return str_pad(trim($text), $cols, $pad_string, $pad_type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function pads($textLeft, $textRight, $pad_string = ' '){
|
||||||
|
global $config;
|
||||||
|
$cols = 37;
|
||||||
|
if($config['printer_cols']){
|
||||||
|
$cols = $config['printer_cols'];
|
||||||
|
}
|
||||||
|
return $textLeft.str_pad($textRight, $cols-strlen($textLeft), $pad_string, 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,14 +62,15 @@ class Message
|
|||||||
if (!empty($config['wa_url'])) {
|
if (!empty($config['wa_url'])) {
|
||||||
$waurl = str_replace('[number]', urlencode($phone), $config['wa_url']);
|
$waurl = str_replace('[number]', urlencode($phone), $config['wa_url']);
|
||||||
$waurl = str_replace('[text]', urlencode($txt), $waurl);
|
$waurl = str_replace('[text]', urlencode($txt), $waurl);
|
||||||
Http::getData($waurl);
|
return Http::getData($waurl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function sendPackageNotification($phone, $name, $package, $message, $via)
|
public static function sendPackageNotification($phone, $name, $package, $price, $message, $via)
|
||||||
{
|
{
|
||||||
$msg = str_replace('[[name]]', "*$name*", $message);
|
$msg = str_replace('[[name]]', $name, $message);
|
||||||
$msg = str_replace('[[package]]', "*$package*", $msg);
|
$msg = str_replace('[[package]]', $package, $msg);
|
||||||
|
$msg = str_replace('[[price]]', $price, $msg);
|
||||||
if (
|
if (
|
||||||
!empty($phone) && strlen($phone) > 5
|
!empty($phone) && strlen($phone) > 5
|
||||||
&& !empty($message) && in_array($via, ['sms', 'wa'])
|
&& !empty($message) && in_array($via, ['sms', 'wa'])
|
||||||
@ -85,9 +86,9 @@ class Message
|
|||||||
|
|
||||||
public static function sendBalanceNotification($phone, $name, $balance, $balance_now, $message, $via)
|
public static function sendBalanceNotification($phone, $name, $balance, $balance_now, $message, $via)
|
||||||
{
|
{
|
||||||
$msg = str_replace('[[name]]', "*$name*", $message);
|
$msg = str_replace('[[name]]', $name, $message);
|
||||||
$msg = str_replace('[[current_balance]]', Lang::moneyFormat($balance_now), $msg);
|
$msg = str_replace('[[current_balance]]', Lang::moneyFormat($balance_now), $msg);
|
||||||
$msg = str_replace('[[balance]]', "*" . Lang::moneyFormat($balance) . "*", $msg);
|
$msg = str_replace('[[balance]]', Lang::moneyFormat($balance), $msg);
|
||||||
if (
|
if (
|
||||||
!empty($phone) && strlen($phone) > 5
|
!empty($phone) && strlen($phone) > 5
|
||||||
&& !empty($message) && in_array($via, ['sms', 'wa'])
|
&& !empty($message) && in_array($via, ['sms', 'wa'])
|
||||||
|
@ -190,7 +190,11 @@ $_notifmsg_default = json_decode(file_get_contents(File::pathFixer('system/uploa
|
|||||||
|
|
||||||
//register all plugin
|
//register all plugin
|
||||||
foreach (glob(File::pathFixer("system/plugin/*.php")) as $filename) {
|
foreach (glob(File::pathFixer("system/plugin/*.php")) as $filename) {
|
||||||
|
try {
|
||||||
include $filename;
|
include $filename;
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
} catch (Exception $e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -299,7 +303,8 @@ function time_elapsed_string($datetime, $full = false)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$full) $string = array_slice($string, 0, 1);
|
if (!$full)
|
||||||
|
$string = array_slice($string, 0, 1);
|
||||||
return $string ? implode(', ', $string) . ' ago' : 'just now';
|
return $string ? implode(', ', $string) . ' ago' : 'just now';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,6 +96,12 @@ if (isset($_GET['recharge']) && !empty($_GET['recharge'])) {
|
|||||||
$router = ORM::for_table('tbl_routers')->where('name', $bill['routers'])->find_one();
|
$router = ORM::for_table('tbl_routers')->where('name', $bill['routers'])->find_one();
|
||||||
if ($config['enable_balance'] == 'yes') {
|
if ($config['enable_balance'] == 'yes') {
|
||||||
$plan = ORM::for_table('tbl_plans')->find_one($bill['plan_id']);
|
$plan = ORM::for_table('tbl_plans')->find_one($bill['plan_id']);
|
||||||
|
if(!$plan['enabled']){
|
||||||
|
r2(U . "home", 'e', 'Plan is not exists');
|
||||||
|
}
|
||||||
|
if($plan['allow_purchase'] != 'yes'){
|
||||||
|
r2(U . "home", 'e', 'Cannot recharge this plan');
|
||||||
|
}
|
||||||
if ($user['balance'] > $plan['price']) {
|
if ($user['balance'] > $plan['price']) {
|
||||||
r2(U . "order/pay/$router[id]/$bill[plan_id]", 'e', 'Order Plan');
|
r2(U . "order/pay/$router[id]/$bill[plan_id]", 'e', 'Order Plan');
|
||||||
} else {
|
} else {
|
||||||
|
@ -149,6 +149,12 @@ switch ($action) {
|
|||||||
if (empty($plan)) {
|
if (empty($plan)) {
|
||||||
r2(U . "order/package", 'e', Lang::T("Plan Not found"));
|
r2(U . "order/package", 'e', Lang::T("Plan Not found"));
|
||||||
}
|
}
|
||||||
|
if(!$plan['enabled']){
|
||||||
|
r2(U . "home", 'e', 'Plan is not exists');
|
||||||
|
}
|
||||||
|
if($plan['allow_purchase'] != 'yes'){
|
||||||
|
r2(U . "home", 'e', 'Cannot recharge this plan');
|
||||||
|
}
|
||||||
if ($routes['2'] == 'radius') {
|
if ($routes['2'] == 'radius') {
|
||||||
$router_name = 'radius';
|
$router_name = 'radius';
|
||||||
} else {
|
} else {
|
||||||
@ -166,7 +172,7 @@ switch ($action) {
|
|||||||
"\nPrice: " . $p['price']);
|
"\nPrice: " . $p['price']);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
echo "no renewall | plan enabled: $p[enabled] | User balance: $c[balance] | price $p[price]\n";
|
r2(U . "home", 'e', 'Plan is not exists');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'send':
|
case 'send':
|
||||||
@ -179,6 +185,12 @@ switch ($action) {
|
|||||||
if (empty($plan)) {
|
if (empty($plan)) {
|
||||||
r2(U . "order/package", 'e', Lang::T("Plan Not found"));
|
r2(U . "order/package", 'e', Lang::T("Plan Not found"));
|
||||||
}
|
}
|
||||||
|
if(!$plan['enabled']){
|
||||||
|
r2(U . "home", 'e', 'Plan is not exists');
|
||||||
|
}
|
||||||
|
if($plan['allow_purchase'] != 'yes'){
|
||||||
|
r2(U . "home", 'e', 'Cannot recharge this plan');
|
||||||
|
}
|
||||||
if ($routes['2'] == 'radius') {
|
if ($routes['2'] == 'radius') {
|
||||||
$router_name = 'radius';
|
$router_name = 'radius';
|
||||||
} else {
|
} else {
|
||||||
|
@ -68,6 +68,8 @@ switch ($action) {
|
|||||||
Mikrotik::removePool($client, $d['pool_name']);
|
Mikrotik::removePool($client, $d['pool_name']);
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
//ignore exception, it means router has already deleted
|
//ignore exception, it means router has already deleted
|
||||||
|
} catch(Throwable $e){
|
||||||
|
//ignore exception, it means router has already deleted
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$d->delete();
|
$d->delete();
|
||||||
|
@ -159,7 +159,7 @@ switch ($action) {
|
|||||||
case 'print':
|
case 'print':
|
||||||
$id = _post('id');
|
$id = _post('id');
|
||||||
$d = ORM::for_table('tbl_transactions')->where('id', $id)->find_one();
|
$d = ORM::for_table('tbl_transactions')->where('id', $id)->find_one();
|
||||||
$ui->assign('d', $d);
|
$ui->assign('in', $d);
|
||||||
|
|
||||||
$ui->assign('date', Lang::dateAndTimeFormat($d['recharged_on'], $d['recharged_time']));
|
$ui->assign('date', Lang::dateAndTimeFormat($d['recharged_on'], $d['recharged_time']));
|
||||||
run_hook('print_invoice'); #HOOK
|
run_hook('print_invoice'); #HOOK
|
||||||
|
@ -173,6 +173,8 @@ switch ($action) {
|
|||||||
Mikrotik::removeHotspotPlan($client, $d['name_plan']);
|
Mikrotik::removeHotspotPlan($client, $d['name_plan']);
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
//ignore exception, it means router has already deleted
|
//ignore exception, it means router has already deleted
|
||||||
|
} catch(Throwable $e){
|
||||||
|
//ignore exception, it means router has already deleted
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -441,6 +443,8 @@ switch ($action) {
|
|||||||
Mikrotik::removePpoePlan($client, $d['name_plan']);
|
Mikrotik::removePpoePlan($client, $d['name_plan']);
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
//ignore exception, it means router has already deleted
|
//ignore exception, it means router has already deleted
|
||||||
|
} catch(Throwable $e){
|
||||||
|
//ignore exception, it means router has already deleted
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$d->delete();
|
$d->delete();
|
||||||
|
@ -68,7 +68,13 @@ $_notifmsg_default = json_decode(file_get_contents('uploads/notifications.defaul
|
|||||||
|
|
||||||
//register all plugin
|
//register all plugin
|
||||||
foreach (glob(File::pathFixer("plugin/*.php")) as $filename) {
|
foreach (glob(File::pathFixer("plugin/*.php")) as $filename) {
|
||||||
|
try{
|
||||||
include $filename;
|
include $filename;
|
||||||
|
} catch(Throwable $e){
|
||||||
|
//ignore plugin error
|
||||||
|
}catch(Exception $e){
|
||||||
|
//ignore plugin error
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = ORM::for_table('tbl_appconfig')->find_many();
|
$result = ORM::for_table('tbl_appconfig')->find_many();
|
||||||
@ -111,9 +117,9 @@ foreach ($d as $ds) {
|
|||||||
echo " : EXPIRED \r\n";
|
echo " : EXPIRED \r\n";
|
||||||
$u = ORM::for_table('tbl_user_recharges')->where('id', $ds['id'])->find_one();
|
$u = ORM::for_table('tbl_user_recharges')->where('id', $ds['id'])->find_one();
|
||||||
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
||||||
$m = ORM::for_table('tbl_routers')->where('name', $ds['routers'])->find_one();
|
$m = Mikrotik::info($ds['routers']);
|
||||||
$p = ORM::for_table('tbl_plans')->where('id', $u['plan_id'])->find_one();
|
$p = ORM::for_table('tbl_plans')->where('id', $u['plan_id'])->find_one();
|
||||||
|
$price = Lang::moneyFormat($p['price']);
|
||||||
if ($p['is_radius']) {
|
if ($p['is_radius']) {
|
||||||
if (empty($p['pool_expired'])) {
|
if (empty($p['pool_expired'])) {
|
||||||
print_r(Radius::customerDeactivate($c['username']));
|
print_r(Radius::customerDeactivate($c['username']));
|
||||||
@ -130,7 +136,7 @@ foreach ($d as $ds) {
|
|||||||
}
|
}
|
||||||
Mikrotik::removeHotspotActiveUser($client, $c['username']);
|
Mikrotik::removeHotspotActiveUser($client, $c['username']);
|
||||||
}
|
}
|
||||||
Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], $textExpired, $config['user_notification_expired']);
|
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], $price, $textExpired, $config['user_notification_expired'])."\n";
|
||||||
//update database user dengan status off
|
//update database user dengan status off
|
||||||
$u->status = 'off';
|
$u->status = 'off';
|
||||||
$u->save();
|
$u->save();
|
||||||
@ -156,7 +162,8 @@ foreach ($d as $ds) {
|
|||||||
} else {
|
} else {
|
||||||
echo "no renewall | balance $config[enable_balance] auto_renewal $c[auto_renewal]\n";
|
echo "no renewall | balance $config[enable_balance] auto_renewal $c[auto_renewal]\n";
|
||||||
}
|
}
|
||||||
} else echo " : ACTIVE \r\n";
|
} else
|
||||||
|
echo " : ACTIVE \r\n";
|
||||||
} else {
|
} else {
|
||||||
$date_now = strtotime(date("Y-m-d H:i:s"));
|
$date_now = strtotime(date("Y-m-d H:i:s"));
|
||||||
$expiration = strtotime($ds['expiration'] . ' ' . $ds['time']);
|
$expiration = strtotime($ds['expiration'] . ' ' . $ds['time']);
|
||||||
@ -167,7 +174,7 @@ foreach ($d as $ds) {
|
|||||||
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
||||||
$m = ORM::for_table('tbl_routers')->where('name', $ds['routers'])->find_one();
|
$m = ORM::for_table('tbl_routers')->where('name', $ds['routers'])->find_one();
|
||||||
$p = ORM::for_table('tbl_plans')->where('id', $u['plan_id'])->find_one();
|
$p = ORM::for_table('tbl_plans')->where('id', $u['plan_id'])->find_one();
|
||||||
|
$price = Lang::moneyFormat($p['price']);
|
||||||
if ($p['is_radius']) {
|
if ($p['is_radius']) {
|
||||||
if (empty($p['pool_expired'])) {
|
if (empty($p['pool_expired'])) {
|
||||||
print_r(Radius::customerDeactivate($c['username']));
|
print_r(Radius::customerDeactivate($c['username']));
|
||||||
@ -184,7 +191,7 @@ foreach ($d as $ds) {
|
|||||||
}
|
}
|
||||||
Mikrotik::removePpoeActive($client, $c['username']);
|
Mikrotik::removePpoeActive($client, $c['username']);
|
||||||
}
|
}
|
||||||
Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], $textExpired, $config['user_notification_expired']);
|
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], $price, $textExpired, $config['user_notification_expired'])."\n";
|
||||||
|
|
||||||
$u->status = 'off';
|
$u->status = 'off';
|
||||||
$u->save();
|
$u->save();
|
||||||
@ -206,6 +213,7 @@ foreach ($d as $ds) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else echo " : ACTIVE \r\n";
|
} else
|
||||||
|
echo " : ACTIVE \r\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,13 @@ $_notifmsg_default = json_decode(file_get_contents('uploads/notifications.defaul
|
|||||||
|
|
||||||
//register all plugin
|
//register all plugin
|
||||||
foreach (glob(File::pathFixer("plugin/*.php")) as $filename) {
|
foreach (glob(File::pathFixer("plugin/*.php")) as $filename) {
|
||||||
|
try{
|
||||||
include $filename;
|
include $filename;
|
||||||
|
} catch(Throwable $e){
|
||||||
|
//ignore plugin error
|
||||||
|
}catch(Exception $e){
|
||||||
|
//ignore plugin error
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = ORM::for_table('tbl_appconfig')->find_many();
|
$result = ORM::for_table('tbl_appconfig')->find_many();
|
||||||
@ -98,13 +104,15 @@ print_r([$day1, $day3, $day7]);
|
|||||||
foreach ($d as $ds) {
|
foreach ($d as $ds) {
|
||||||
if (in_array($ds['expiration'], [$day1, $day3, $day7])) {
|
if (in_array($ds['expiration'], [$day1, $day3, $day7])) {
|
||||||
$u = ORM::for_table('tbl_user_recharges')->where('id', $ds['id'])->find_one();
|
$u = ORM::for_table('tbl_user_recharges')->where('id', $ds['id'])->find_one();
|
||||||
|
$p = ORM::for_table('tbl_plans')->where('id', $u['plan_id'])->find_one();
|
||||||
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
$c = ORM::for_table('tbl_customers')->where('id', $ds['customer_id'])->find_one();
|
||||||
|
$price = Lang::moneyFormat($p['price']);
|
||||||
if ($ds['expiration'] == $day7) {
|
if ($ds['expiration'] == $day7) {
|
||||||
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], Lang::getNotifText('reminder_7_day'), $config['user_notification_reminder']) . "\n";
|
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $p['name_plan'], $price, Lang::getNotifText('reminder_7_day'), $config['user_notification_reminder']) . "\n";
|
||||||
} else if ($ds['expiration'] == $day3) {
|
} else if ($ds['expiration'] == $day3) {
|
||||||
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], Lang::getNotifText('reminder_3_day'), $config['user_notification_reminder']) . "\n";
|
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $p['name_plan'], $price, Lang::getNotifText('reminder_3_day'), $config['user_notification_reminder']) . "\n";
|
||||||
} else if ($ds['expiration'] == $day1) {
|
} else if ($ds['expiration'] == $day1) {
|
||||||
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $u['namebp'], Lang::getNotifText('reminder_1_day'), $config['user_notification_reminder']) . "\n";
|
echo Message::sendPackageNotification($c['phonenumber'], $c['fullname'], $p['name_plan'], $price, Lang::getNotifText('reminder_1_day'), $config['user_notification_reminder']) . "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
-----------------------------------
|
-----------------------------------
|
||||||
Language Name: English
|
Language Name: English
|
||||||
Contributor: Ismail Marzuqi
|
Contributor: Ismail Marzuqi
|
||||||
Web: www.phpnuxbill.com
|
|
||||||
Email: iesien22@yahoo.com
|
|
||||||
|
|
||||||
2017
|
2017
|
||||||
Contributor: Ibnu Maksum (@ibnux)
|
Contributor: Ibnu Maksum (@ibnux)
|
||||||
@ -261,7 +259,6 @@ $_L['Plan_Not_found'] = 'Plan Not found';
|
|||||||
$_L['Failed_to_create_transaction'] = 'Failed to create transaction.';
|
$_L['Failed_to_create_transaction'] = 'Failed to create transaction.';
|
||||||
$_L['Seller_has_not_yet_setup_Xendit_payment_gateway'] = 'Seller has not yet setup Xendit payment gateway';
|
$_L['Seller_has_not_yet_setup_Xendit_payment_gateway'] = 'Seller has not yet setup Xendit payment gateway';
|
||||||
$_L['Admin_has_not_yet_setup_Xendit_payment_gateway_please_tell_admin'] = 'Admin has not yet setup Xendit payment gateway, please tell admin';
|
$_L['Admin_has_not_yet_setup_Xendit_payment_gateway_please_tell_admin'] = 'Admin has not yet setup Xendit payment gateway, please tell admin';
|
||||||
$_L['Buy_this_your_active_package_will_be_overwrite'] = 'Buy this? your active package will be overwrite';
|
|
||||||
$_L['You_already_have_unpaid_transaction_cancel_it_or_pay_it'] = 'You already have unpaid transaction, cancel it or pay it.';
|
$_L['You_already_have_unpaid_transaction_cancel_it_or_pay_it'] = 'You already have unpaid transaction, cancel it or pay it.';
|
||||||
$_L['Transaction_Not_found'] = 'Transaction Not found';
|
$_L['Transaction_Not_found'] = 'Transaction Not found';
|
||||||
$_L['Cancel_it'] = 'Cancel it?';
|
$_L['Cancel_it'] = 'Cancel it?';
|
||||||
@ -314,7 +311,6 @@ $_L['User_Notification'] = 'User Notification';
|
|||||||
$_L['Expired_Notification'] = 'Expired Notification';
|
$_L['Expired_Notification'] = 'Expired Notification';
|
||||||
$_L['User_will_get_notification_when_package_expired'] = 'User will get notification when package expired';
|
$_L['User_will_get_notification_when_package_expired'] = 'User will get notification when package expired';
|
||||||
$_L['Expired_Notification_Message'] = 'Expired Notification Message';
|
$_L['Expired_Notification_Message'] = 'Expired Notification Message';
|
||||||
$_L['bnameb_will_be_replaced_with_Customer_Name_bpackageb_will_be_replaced_with_Package_name'] = '<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name.';
|
|
||||||
$_L['Payment_Notification'] = 'Payment Notification';
|
$_L['Payment_Notification'] = 'Payment Notification';
|
||||||
$_L['User_will_get_invoice_notification_when_buy_package_or_package_refilled'] = 'User will get invoice notification when buy package or package refilled';
|
$_L['User_will_get_invoice_notification_when_buy_package_or_package_refilled'] = 'User will get invoice notification when buy package or package refilled';
|
||||||
$_L['Current_IP'] = 'Current IP';
|
$_L['Current_IP'] = 'Current IP';
|
||||||
@ -420,3 +416,5 @@ $_L['After_Customer_activate_voucher_or_login_customer_will_be_redirected_to_thi
|
|||||||
$_L['Voucher_Prefix'] = 'Voucher Prefix';
|
$_L['Voucher_Prefix'] = 'Voucher Prefix';
|
||||||
$_L['Voucher_activation_success_now_you_can_login'] = 'Voucher activation success, now you can login';
|
$_L['Voucher_activation_success_now_you_can_login'] = 'Voucher activation success, now you can login';
|
||||||
$_L['Client_Can_Purchase'] = 'Client Can Purchase';
|
$_L['Client_Can_Purchase'] = 'Client Can Purchase';
|
||||||
|
$_L['Buy_this_your_active_package_will_be_overwritten'] = 'Buy this? your active package will be overwritten';
|
||||||
|
$_L['Pay_this_with_Balance_your_active_package_will_be_overwritten'] = 'Pay this with Balance? your active package will be overwritten';
|
||||||
|
@ -3,9 +3,6 @@
|
|||||||
-----------------------------------
|
-----------------------------------
|
||||||
Language Name: Indonesia
|
Language Name: Indonesia
|
||||||
Contributor: Ismail Marzuqi
|
Contributor: Ismail Marzuqi
|
||||||
Web: www.phpnuxbill.com
|
|
||||||
Email: iesien22@yahoo.com
|
|
||||||
|
|
||||||
2017
|
2017
|
||||||
Contributor: Ibnu Maksum (@ibnux)
|
Contributor: Ibnu Maksum (@ibnux)
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
rows="3">{if $_json['expired']!=''}{Lang::htmlspecialchars($_json['expired'])}{else}Hello [[name]], your internet package [[package]] has been expired.{/if}</textarea>
|
rows="3">{if $_json['expired']!=''}{Lang::htmlspecialchars($_json['expired'])}{else}Hello [[name]], your internet package [[package]] has been expired.{/if}</textarea>
|
||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">
|
<p class="help-block col-md-4">
|
||||||
{Lang::T('<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name.')}
|
<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name. <b>[[price]]</b> will be replaced with Package price.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -33,7 +33,7 @@
|
|||||||
rows="3">{Lang::htmlspecialchars($_json['reminder_7_day'])}</textarea>
|
rows="3">{Lang::htmlspecialchars($_json['reminder_7_day'])}</textarea>
|
||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">
|
<p class="help-block col-md-4">
|
||||||
{Lang::T('<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name.')}
|
<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name. <b>[[price]]</b> will be replaced with Package price.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -45,7 +45,7 @@
|
|||||||
rows="3">{Lang::htmlspecialchars($_json['reminder_3_day'])}</textarea>
|
rows="3">{Lang::htmlspecialchars($_json['reminder_3_day'])}</textarea>
|
||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">
|
<p class="help-block col-md-4">
|
||||||
{Lang::T('<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name.')}
|
<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name. <b>[[price]]</b> will be replaced with Package price.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -57,7 +57,7 @@
|
|||||||
rows="3">{Lang::htmlspecialchars($_json['reminder_1_day'])}</textarea>
|
rows="3">{Lang::htmlspecialchars($_json['reminder_1_day'])}</textarea>
|
||||||
</div>
|
</div>
|
||||||
<p class="help-block col-md-4">
|
<p class="help-block col-md-4">
|
||||||
{Lang::T('<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name.')}
|
<b>[[name]]</b> will be replaced with Customer Name. <b>[[package]]</b> will be replaced with Package name. <b>[[price]]</b> will be replaced with Package price.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -53,6 +53,14 @@
|
|||||||
<input type="text" class="form-control" id="phone" name="phone" value="{$_c['phone']}">
|
<input type="text" class="form-control" id="phone" name="phone" value="{$_c['phone']}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-md-2 control-label"><i class="glyphicon glyphicon-print"></i> Print Max Char</label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<input type="number" required class="form-control" id="printer_cols" placeholder="37" name="printer_cols"
|
||||||
|
value="{$_c['printer_cols']}">
|
||||||
|
</div>
|
||||||
|
<span class="help-block col-md-4">For invoice print using Thermal Printer</span>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-md-2 control-label">Theme</label>
|
<label class="col-md-2 control-label">Theme</label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
|
@ -175,12 +175,7 @@
|
|||||||
if (cek.checked) {
|
if (cek.checked) {
|
||||||
$("#routerChoose").addClass('hidden');
|
$("#routerChoose").addClass('hidden');
|
||||||
document.getElementById("routers").required = false;
|
document.getElementById("routers").required = false;
|
||||||
} else {
|
$("#pool_expired").html('');
|
||||||
document.getElementById("routers").required = true;
|
|
||||||
$("#routerChoose").removeClass('hidden');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
setTimeout(() => {
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: "index.php?_route=autoload/pool",
|
url: "index.php?_route=autoload/pool",
|
||||||
data: "routers=radius",
|
data: "routers=radius",
|
||||||
@ -189,7 +184,11 @@
|
|||||||
$("#pool_expired").html(msg);
|
$("#pool_expired").html(msg);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}, 2000);
|
} else {
|
||||||
|
document.getElementById("routers").required = true;
|
||||||
|
$("#routerChoose").removeClass('hidden');
|
||||||
|
}
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
{/literal}
|
{/literal}
|
||||||
{/if}
|
{/if}
|
||||||
|
@ -179,7 +179,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{if $_c['radius_enable']}
|
{if $_c['radius_enable'] && $d['is_radius']}
|
||||||
{literal}
|
{literal}
|
||||||
<script>
|
<script>
|
||||||
function isRadius(cek) {
|
function isRadius(cek) {
|
||||||
|
@ -49,7 +49,8 @@
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{foreach $d as $ds}
|
{foreach $d as $ds}
|
||||||
<tr {if $ds['enabled'] != 1}class="danger" title="disabled" {/if}>
|
<tr {if $ds['enabled'] != 1}class="danger" title="disabled"
|
||||||
|
{elseif $ds['allow_purchase'] != 'yes'}class="warning" title="Customer can't purchase" {/if}>
|
||||||
<td>{$ds['name_plan']}</td>
|
<td>{$ds['name_plan']}</td>
|
||||||
<td>{$ds['typebp']}</td>
|
<td>{$ds['typebp']}</td>
|
||||||
<td>{$ds['name_bw']}</td>
|
<td>{$ds['name_bw']}</td>
|
||||||
|
@ -21,30 +21,27 @@
|
|||||||
<table width="200">
|
<table width="200">
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<fieldset>
|
<pre style="border-style: none; background-color: white;"><b>{Lang::pad($_c['CompanyName'],' ', 2)}</b>
|
||||||
<center>
|
{Lang::pad($_c['address'],' ', 2)}
|
||||||
<b>{$_c['CompanyName']}</b><br>
|
{Lang::pad($_c['phone'],' ', 2)}
|
||||||
{$_c['address']}<br>
|
{Lang::pad("", '=')}
|
||||||
{$_c['phone']}<br>
|
{Lang::pads("Invoice", $in['invoice'], ' ')}
|
||||||
</center>
|
{Lang::pads($_L['Date'], $date, ' ')}
|
||||||
============================================<br>
|
{Lang::pads($_L['Sales'], $_admin['fullname'], ' ')}
|
||||||
INVOICE: <b>{$d['invoice']}</b> - {$_L['Date']} : {$date}<br>
|
{Lang::pad("", '=')}
|
||||||
{$_L['Sales']} : {$_admin['fullname']}<br>
|
{Lang::pads($_L['Type'], $in['type'], ' ')}
|
||||||
============================================<br>
|
{Lang::pads($_L['Plan_Name'], $in['plan_name'], ' ')}
|
||||||
{$_L['Type']} : <b>{$d['type']}</b><br>
|
{Lang::pads($_L['Plan_Price'], Lang::moneyFormat($in['price']), ' ')}
|
||||||
{$_L['Plan_Name']} : <b>{$d['plan_name']}</b><br>
|
{Lang::pad($in['method'], ' ', 2)}
|
||||||
{$_L['Plan_Price']} : <b>{Lang::moneyFormat($d['price'])}</b><br>
|
|
||||||
<br>
|
{Lang::pads($_L['Username'], $in['username'], ' ')}
|
||||||
{$_L['Username']} : <b>{$d['username']}</b><br>
|
{Lang::pads($_L['Password'], '**********', ' ')}
|
||||||
{$_L['Password']} : **********<br>
|
|
||||||
{if $in['type'] != 'Balance'}
|
{if $in['type'] != 'Balance'}
|
||||||
<br>
|
{Lang::pads($_L['Created_On'], Lang::dateAndTimeFormat($in['recharged_on'],$in['recharged_time']), ' ')}
|
||||||
{$_L['Created_On']} : <b>{Lang::dateAndTimeFormat($d['recharged_on'],$d['recharged_time'])}</b><br>
|
{Lang::pads($_L['Expires_On'], Lang::dateAndTimeFormat($in['expiration'],$in['time']), ' ')}
|
||||||
{$_L['Expires_On']} : <b>{Lang::dateAndTimeFormat($d['expiration'],$d['time'])}</b><br>
|
|
||||||
{/if}
|
{/if}
|
||||||
============================================<br>
|
{Lang::pad("", '=')}
|
||||||
<center>{$_c['note']}</center>
|
{Lang::pad($_c['note'],' ', 2)}</pre>
|
||||||
</fieldset>
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
@ -5,33 +5,27 @@
|
|||||||
<div class="panel panel-hovered panel-primary panel-stacked mb30">
|
<div class="panel panel-hovered panel-primary panel-stacked mb30">
|
||||||
<div class="panel-heading">{$in['invoice']}</div>
|
<div class="panel-heading">{$in['invoice']}</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<div class="well">
|
<pre><b>{Lang::pad($_c['CompanyName'],' ', 2)}</b>
|
||||||
<fieldset>
|
{Lang::pad($_c['address'],' ', 2)}
|
||||||
<center>
|
{Lang::pad($_c['phone'],' ', 2)}
|
||||||
<b>{$_c['CompanyName']}</b><br>
|
{Lang::pad("", '=')}
|
||||||
{$_c['address']}<br>
|
{Lang::pads("Invoice", $in['invoice'], ' ')}
|
||||||
{$_c['phone']}<br>
|
{Lang::pads($_L['Date'], $date, ' ')}
|
||||||
</center>
|
{Lang::pads($_L['Sales'], $_admin['fullname'], ' ')}
|
||||||
====================================================<br>
|
{Lang::pad("", '=')}
|
||||||
INVOICE: <b>{$in['invoice']}</b> - {$_L['Date']} : {$date}<br>
|
{Lang::pads($_L['Type'], $in['type'], ' ')}
|
||||||
{$_L['Sales']} : {$_admin['fullname']}<br>
|
{Lang::pads($_L['Plan_Name'], $in['plan_name'], ' ')}
|
||||||
====================================================<br>
|
{Lang::pads($_L['Plan_Price'], Lang::moneyFormat($in['price']), ' ')}
|
||||||
{$_L['Type']} : <b>{$in['type']}</b><br>
|
{Lang::pad($in['method'], ' ', 2)}
|
||||||
{$_L['Plan_Name']} : <b>{$in['plan_name']}</b><br>
|
|
||||||
{$_L['Plan_Price']} : <b>{Lang::moneyFormat($in['price'])}</b><br>
|
{Lang::pads($_L['Username'], $in['username'], ' ')}
|
||||||
{$in['method']}<br>
|
{Lang::pads($_L['Password'], '**********', ' ')}
|
||||||
<br>
|
|
||||||
{$_L['Username']} : <b>{$in['username']}</b><br>
|
|
||||||
{$_L['Password']} : **********<br>
|
|
||||||
{if $in['type'] != 'Balance'}
|
{if $in['type'] != 'Balance'}
|
||||||
<br>
|
{Lang::pads($_L['Created_On'], Lang::dateAndTimeFormat($in['recharged_on'],$in['recharged_time']), ' ')}
|
||||||
{$_L['Created_On']} : <b>{Lang::dateAndTimeFormat($in['recharged_on'],$in['recharged_time'])}</b><br>
|
{Lang::pads($_L['Expires_On'], Lang::dateAndTimeFormat($in['expiration'],$in['time']), ' ')}
|
||||||
{$_L['Expires_On']} : <b>{Lang::dateAndTimeFormat($in['expiration'],$in['time'])}</b><br>
|
|
||||||
{/if}
|
{/if}
|
||||||
=====================================================<br>
|
{Lang::pad("", '=')}
|
||||||
<center>{$_c['note']}</center>
|
{Lang::pad($_c['note'],' ', 2)}</pre>
|
||||||
</fieldset>
|
|
||||||
</div>
|
|
||||||
<form class="form-horizontal" method="post" action="{$_url}prepaid/print" target="_blank">
|
<form class="form-horizontal" method="post" action="{$_url}prepaid/print" target="_blank">
|
||||||
<input type="hidden" name="id" value="{$in['id']}">
|
<input type="hidden" name="id" value="{$in['id']}">
|
||||||
<a href="{$_url}prepaid/list" class="btn btn-primary btn-sm"><i
|
<a href="{$_url}prepaid/list" class="btn btn-primary btn-sm"><i
|
||||||
|
@ -121,7 +121,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{if $_c['radius_enable'] and $d['is_radius']}
|
{if $_c['radius_enable'] && $d['is_radius']}
|
||||||
{literal}
|
{literal}
|
||||||
<script>
|
<script>
|
||||||
document.getElementById("routers").required = false;
|
document.getElementById("routers").required = false;
|
||||||
|
@ -47,7 +47,8 @@
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{foreach $d as $ds}
|
{foreach $d as $ds}
|
||||||
<tr {if $ds['enabled'] != 1}class="danger" title="disabled" {/if}>
|
<tr {if $ds['enabled'] != 1}class="danger" title="disabled"
|
||||||
|
{elseif $ds['allow_purchase'] != 'yes'}class="warning" title="Customer can't purchase" {/if}>
|
||||||
<td>{$ds['name_plan']}</td>
|
<td>{$ds['name_plan']}</td>
|
||||||
<td>{$ds['name_bw']}</td>
|
<td>{$ds['name_bw']}</td>
|
||||||
<td>{Lang::moneyFormat($ds['price'])}</td>
|
<td>{Lang::moneyFormat($ds['price'])}</td>
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
{
|
{
|
||||||
"version": "2024.1.11"
|
"version": "2024.1.16.2"
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user