2024-07-10 18:28:19 +05:45
|
|
|
<?php
|
|
|
|
defined('BASEPATH') or exit('No direct script access allowed');
|
|
|
|
class Vouchers extends CI_Controller
|
|
|
|
{
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
$this->load->helper("accounts");
|
|
|
|
$this->load->library("myaccounts");
|
|
|
|
checkLogin();
|
|
|
|
}
|
|
|
|
public function _remap($alias = "", $params = array())
|
|
|
|
{
|
|
|
|
|
|
|
|
$data['dataValue'] = $this->session;
|
|
|
|
$data['pageTitle'] = "Accounting Vouchers";
|
|
|
|
switch ($alias) {
|
|
|
|
case 'print':
|
|
|
|
$voucher_id = $this->uri->segment(4);
|
|
|
|
$VoucherPDF = $this->myaccounts->voucherPDF($voucher_id);
|
|
|
|
$data['PDFFile'] = site_url("pdf/vouchers/" . $VoucherPDF);
|
|
|
|
if (isset($_GET['modal']))
|
|
|
|
$this->load->view("accounts/pdfviewer", $data);
|
|
|
|
else
|
|
|
|
loadView("accounts/pdfviewer", $data);
|
|
|
|
break;
|
|
|
|
case 'listvouchers':
|
|
|
|
$data['pageTitle'] = "Vouchers";
|
2024-08-21 13:47:09 +05:45
|
|
|
$data['fiscalStart'] = NepaliDate($this->session->userdata['FiscalYear']->fiscalyear_from);
|
|
|
|
$data['fiscalEnd'] = NepaliDate($this->session->userdata['FiscalYear']->fiscalyear_to);
|
2024-07-10 18:28:19 +05:45
|
|
|
$fromDate_bs = isset($_GET['from_date']) ? $_GET['from_date'] : firstDayOfNepaliMonth();
|
|
|
|
$todate_bs = isset($_GET['to_date']) ? $_GET['to_date'] : NepaliDate(Today());
|
|
|
|
$fromDate_ad = NepaliToEnglishDate($fromDate_bs);
|
|
|
|
$toDate_ad = NepaliToEnglishDate($todate_bs);
|
|
|
|
$data['fromDate_bs'] = $fromDate_bs;
|
|
|
|
$data['toDate_bs'] = $todate_bs;
|
|
|
|
$data['fromDate_ad'] = $fromDate_ad;
|
|
|
|
$data['toDate_ad'] = $toDate_ad;
|
|
|
|
$data['VoucherTypes']=$this->myaccounts->getVoucherTypes();
|
|
|
|
loadView("accounts/vouchers/listvouchers", $data);
|
|
|
|
break;
|
|
|
|
case 'addvoucher':
|
|
|
|
$data['pageTitle'] = "Journal Voucher";
|
|
|
|
if (isset($_POST['submit']) && !isVoucherExists($_POST['voucher_no'])) {
|
|
|
|
$TableData = array(
|
|
|
|
'voucher_no' => filter_var($_POST['voucher_no']),
|
|
|
|
'voucher_ref' => "JV" . filter_var($_POST['voucher_no']), // If the voucher is raised against other transactions
|
|
|
|
'voucher_date' => NepaliToEnglishDate(filter_var($_POST['voucher_date'])),
|
|
|
|
'voucher_state' => 'Entered', // Different stages of voucher Entered/Reversed/Cancel/Deleted/Locked/Draft etc.
|
|
|
|
'voucher_type' => 'Journal', //Different types of Vouchers like Cash/Bank/Payment/Receipt/advance etc.
|
|
|
|
'fiscalyear_id' => $this->session->userdata("FiscalYearID"),
|
|
|
|
'branch_id' => $this->session->userdata("BranchID"),
|
|
|
|
'created_by' => $this->session->userdata("loggedUser"),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_vouchers', $TableData);
|
|
|
|
$voucher_id = $this->db->insert_id();
|
|
|
|
$account_ids = $_POST['account_ids'];
|
|
|
|
$narrations = $_POST['narration'];
|
|
|
|
$debits = $_POST['debit'];
|
|
|
|
$credits = $_POST['credit'];
|
|
|
|
$entry_no = 0;
|
|
|
|
for ($entry_no = 0; $entry_no < sizeof($account_ids); $entry_no++) {
|
|
|
|
$TableData = array();
|
|
|
|
$TableData = array(
|
|
|
|
'voucher_id' => $voucher_id,
|
|
|
|
'entry_no' => $entry_no,
|
|
|
|
'transaction_date' => NepaliToEnglishDate(filter_var($_POST['voucher_date'])),
|
|
|
|
'account_id' => $account_ids[$entry_no],
|
|
|
|
'narration' => $narrations[$entry_no],
|
|
|
|
'dr' => $debits[$entry_no],
|
|
|
|
'cr' => $credits[$entry_no],
|
|
|
|
// 'cheque' => filter_var($_POST['cheque']),
|
|
|
|
// 'cheque_details' => filter_var($_POST['cheque_details']),
|
|
|
|
'currency' => 'NPR',
|
|
|
|
// 'exrate' => filter_var($_POST['exrate']),
|
|
|
|
// 'fcdr' => filter_var($_POST['fcdr']),
|
|
|
|
// 'fccr' => filter_var($_POST['fccr']),
|
|
|
|
'branch_id' => $this->session->userdata("BranchID"),
|
|
|
|
'fiscalyear_id' => $this->session->userdata("FiscalYearID"),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => $this->session->userdata("loggedUser"),
|
|
|
|
// 'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_voucherdetails', $TableData);
|
|
|
|
}
|
|
|
|
redirect("accounts/vouchers/print/" . $voucher_id);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
loadView("accounts/vouchers/addvoucher", $data);
|
|
|
|
break;
|
|
|
|
case 'voucherdetails':
|
|
|
|
$voucher_id = $this->uri->segment(4);
|
|
|
|
$Voucher = $this->db->where("voucher_id", $voucher_id)->get("tbl_vouchers")->row();
|
|
|
|
$Voucher->Details = $this->db->where("voucher_id", $voucher_id)->get("tbl_voucherdetails")->result();
|
|
|
|
$data['Voucher'] = $Voucher;
|
|
|
|
$this->load->view("accounts/vouchers/voucherdetails", $data);
|
|
|
|
break;
|
|
|
|
case 'show_voucher':
|
|
|
|
$data['pageTitle'] = "Voucher Entries";
|
|
|
|
$voucher_id = $this->uri->segment(4);
|
|
|
|
$Voucher = $this->db->where("voucher_id", $voucher_id)->get("tbl_vouchers")->row();
|
|
|
|
if($Voucher) {
|
|
|
|
$Voucher->Details = $this->db->where("voucher_id", $voucher_id)->get("tbl_voucherdetails")->result();
|
|
|
|
$data['Voucher'] = $Voucher;
|
|
|
|
$data['voucher_id'] = $voucher_id;
|
|
|
|
loadview("accounts/vouchers/show_voucher", $data);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'reversal':
|
|
|
|
$voucher_id = $this->uri->segment(4);
|
|
|
|
if (isVoucherReverseable($voucher_id)) :
|
|
|
|
$VoucherDetails = $this->db->where("voucher_id", $voucher_id)->get("tbl_voucherdetails")->result();
|
|
|
|
$entry_no = 0;
|
|
|
|
foreach ($VoucherDetails as $VoucherDetail) :
|
|
|
|
$TableData = array(
|
|
|
|
'voucher_id' => $voucher_id,
|
|
|
|
'entry_no' => $entry_no,
|
|
|
|
'transaction_date' => $VoucherDetail->transaction_date,
|
|
|
|
'account_id' => $VoucherDetail->account_id,
|
|
|
|
'narration' => "Reversal of Voucher #" . getFieldfromValue("tbl_vouchers", "voucher_no", "voucher_id", $VoucherDetail->voucher_id),
|
|
|
|
'dr' => $VoucherDetail->cr,
|
|
|
|
'cr' => $VoucherDetail->dr,
|
|
|
|
// 'cheque' => filter_var($_POST['cheque']),
|
|
|
|
// 'cheque_details' => filter_var($_POST['cheque_details']),
|
|
|
|
'currency' => 'NPR',
|
|
|
|
// 'exrate' => filter_var($_POST['exrate']),
|
|
|
|
// 'fcdr' => filter_var($_POST['fcdr']),
|
|
|
|
// 'fccr' => filter_var($_POST['fccr']),
|
|
|
|
'branch_id' => $this->session->userdata("BranchID"),
|
|
|
|
'fiscalyear_id' => $this->session->userdata("FiscalYearID"),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => $this->session->userdata("loggedUser"),
|
|
|
|
// 'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_voucherdetails', $TableData);
|
|
|
|
$entry_no++;
|
|
|
|
endforeach;
|
|
|
|
$this->db->where("voucher_id", $voucher_id)->set("voucher_state", 'Reversed')->update("tbl_vouchers");
|
|
|
|
endif;
|
|
|
|
redirect("accounts/vouchers/listvouchers");
|
|
|
|
break;
|
2024-07-16 12:43:55 +05:45
|
|
|
|
|
|
|
case 'saveaccount':
|
|
|
|
if (isset($_POST['submit'])) {
|
|
|
|
if (!$this->checkifAccountExists($_POST['account_name'])) {
|
|
|
|
$TableData = array(
|
|
|
|
'accategory_id' => filter_var($_POST['accategory_id']),
|
|
|
|
// 'account_code' => generateAccountCode(filter_var($_POST['account_code'])),
|
|
|
|
'account_name' => filter_var($_POST['account_name']),
|
|
|
|
// 'account_type' => filter_var($_POST['account_type']),
|
|
|
|
// 'account_plcategory' => filter_var($_POST['account_plcategory']),
|
|
|
|
// 'account_currency' => filter_var($_POST['account_currency']),
|
|
|
|
// 'account_partyname' => filter_var($_POST['account_partyname']),
|
|
|
|
// 'account_partyaddress' => filter_var($_POST['account_partyaddress']),
|
|
|
|
// 'account_partypan' => filter_var($_POST['account_partypan']),
|
|
|
|
// 'account_partycontact' => filter_var($_POST['account_partycontact']),
|
|
|
|
// 'account_partyemail' => filter_var($_POST['account_partyemail']),
|
|
|
|
// 'account_partycontactperson' => filter_var($_POST['account_partycontactperson']),
|
|
|
|
// 'account_partycontactpersoncontact' => filter_var($_POST['account_partycontactpersoncontact']),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => 'admin',
|
|
|
|
'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1,
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_accounts', $TableData);
|
|
|
|
$account_id = $this->db->insert_id();
|
|
|
|
$voucherData = array(
|
|
|
|
"voucher_id" => 0,
|
|
|
|
"transaction_date" => date("Y-m-d"),
|
|
|
|
"account_id" => $account_id,
|
|
|
|
"Dr" => 0,
|
|
|
|
"Cr" => 0,
|
|
|
|
"fiscalyear_id" => $this->session->userdata['FiscalYearID'],
|
|
|
|
"created_on" => date('Y-m-d H:i:s'),
|
|
|
|
"branch_id" => $this->session->userdata("BranchID"),
|
|
|
|
"created_by" => $this->session->userdata("loggedUser"),
|
|
|
|
"remarks" => "Opening Balance Entry",
|
|
|
|
"status" => 1
|
|
|
|
);
|
|
|
|
if ($_POST['opening_balance_drcr'] == "DR") $voucherData['Dr'] = $_POST['opening_balance'];
|
|
|
|
if ($_POST['opening_balance_drcr'] == "CR") $voucherData['Cr'] = $_POST['opening_balance'];
|
|
|
|
$this->db->insert('tbl_voucherdetails', $voucherData);
|
|
|
|
redirect("accounts/accountheads/list");
|
|
|
|
} else {
|
|
|
|
echo "Account Head Name Already Exists";
|
|
|
|
die;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
loadView("accounts/accountheads/add", $data);
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
2024-07-10 18:28:19 +05:45
|
|
|
default:
|
|
|
|
if ($VoucherType = $this->myaccounts->getVoucherType($alias)) {
|
|
|
|
$this->processVoucher($VoucherType);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
loadView("accounts/vouchers/listvouchers", $data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
private function processVoucher($VoucherType)
|
|
|
|
{
|
|
|
|
$data['pageTitle'] = $VoucherType->voucher_name;
|
|
|
|
$data['VoucherType'] = $VoucherType;
|
2024-07-26 12:50:15 +05:45
|
|
|
$data['fiscalStart'] = NepaliDate($this->session->userdata['FiscalYear']->fiscalyear_from);
|
|
|
|
$data['fiscalEnd'] = NepaliDate($this->session->userdata['FiscalYear']->fiscalyear_to);
|
2024-07-10 18:28:19 +05:45
|
|
|
$command = $this->uri->segment(4);
|
|
|
|
switch ($command) {
|
|
|
|
case 'create':
|
|
|
|
$voucher_no = generateVoucherNo($VoucherType->vouchertype_id);
|
|
|
|
if (isset($_POST['submit'])) {
|
|
|
|
$TableData = array(
|
|
|
|
'voucher_no' => $voucher_no,
|
|
|
|
'voucher_ref' => $VoucherType->vouchertype_id,
|
|
|
|
'voucher_date' => NepaliToEnglishDate(filter_var($_POST['voucher_date'])),
|
|
|
|
'voucher_state' => 'Entered', // Different stages of voucher Entered/Reversed/Cancel/Deleted/Locked/Draft etc.
|
|
|
|
'voucher_type' => $VoucherType->vouchertype_id, //Different types of Vouchers like Cash/Bank/Payment/Receipt/advance etc.
|
|
|
|
'fiscalyear_id' => $this->session->userdata("FiscalYearID"),
|
|
|
|
'branch_id' => $this->session->userdata("BranchID"),
|
|
|
|
'created_by' => $this->session->userdata("loggedUser"),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
// 'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_vouchers', $TableData);
|
|
|
|
$voucher_id = $this->db->insert_id();
|
|
|
|
$account_ids = $_POST['account_ids'];
|
|
|
|
$narration = $_POST['narration'];
|
|
|
|
$debits = $_POST['debit'];
|
|
|
|
$credits = $_POST['credit'];
|
|
|
|
$entry_no = 0;
|
|
|
|
$entryTotal = 0;
|
|
|
|
for ($entry_no = 0; $entry_no < sizeof($account_ids); $entry_no++) {
|
|
|
|
$TableData = array();
|
|
|
|
$entryTotal += $debits[$entry_no];
|
|
|
|
$TableData = array(
|
|
|
|
'voucher_id' => $voucher_id,
|
|
|
|
'entry_no' => $entry_no,
|
|
|
|
'transaction_date' => NepaliToEnglishDate(filter_var($_POST['voucher_date'])),
|
|
|
|
'account_id' => $account_ids[$entry_no],
|
|
|
|
'narration' => $narration,
|
|
|
|
'dr' => $debits[$entry_no],
|
|
|
|
'cr' => $credits[$entry_no],
|
|
|
|
// 'cheque' => isset($_POST['cheque_number']) ? $_POST['cheque_number'][$entry_no] : "",
|
|
|
|
// 'cheque_details' => isset($_POST['cheque_details']) ? $_POST['cheque_details'][$entry_no] : "",
|
|
|
|
'currency' => 'NPR',
|
|
|
|
// 'exrate' => filter_var($_POST['exrate']),
|
|
|
|
// 'fcdr' => filter_var($_POST['fcdr']),
|
|
|
|
// 'fccr' => filter_var($_POST['fccr']),
|
|
|
|
'branch_id' => $this->session->userdata("BranchID"),
|
|
|
|
'fiscalyear_id' => $this->session->userdata("FiscalYearID"),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => $this->session->userdata("loggedUser"),
|
|
|
|
// 'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1
|
|
|
|
);
|
|
|
|
//pre($TableData);die;
|
|
|
|
$this->db->insert('tbl_voucherdetails', $TableData);
|
|
|
|
}
|
|
|
|
$entry_no++;
|
|
|
|
|
|
|
|
|
2024-08-05 13:13:06 +05:45
|
|
|
// echo json_encode(['status' => 'success']);
|
2024-07-26 12:50:15 +05:45
|
|
|
loadview("accounts/vouchers/create", $data);
|
2024-07-10 18:28:19 +05:45
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
loadview("accounts/vouchers/create", $data);
|
|
|
|
// loadview("accounts/vouchers/$VoucherType->voucher_alias/create", $data);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// $dirname = getcwd() . "/application/views/accounts/vouchers/$VoucherType->voucher_alias";
|
|
|
|
// $filename = $dirname . "/create.php";
|
|
|
|
// //echo getcwd() . "\n";die;
|
|
|
|
// if (!file_exists($filename)) {
|
|
|
|
// mkdir($dirname, 0777);
|
|
|
|
// $this->createView($filename);
|
|
|
|
// $filename = $dirname . "/list.php";
|
|
|
|
// $this->createListView($filename);
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$data['Vouchers'] = $this->db->where("status", 1)->where("voucher_type", $VoucherType->vouchertype_id)->get("tbl_vouchers")->result();
|
|
|
|
|
|
|
|
// echo '<pre>' . $VoucherType->vouchertype_id;
|
|
|
|
// print_r($VoucherType);
|
|
|
|
// die();
|
|
|
|
|
|
|
|
// loadview("accounts/vouchers/$VoucherType->voucher_alias/list", $data);
|
|
|
|
redirect("accounts/vouchers/listvouchers?vouchertypes=".$VoucherType->vouchertype_id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
private function createView($filename)
|
|
|
|
{
|
|
|
|
$CreateFileContent = "<div class=\"content-wrapper\">\n
|
|
|
|
<div class=\"content-header\">\n
|
|
|
|
<div class=\"container-fluid\">\n
|
|
|
|
<div class=\"row mb-2\">\n
|
|
|
|
<div class=\"col-sm-6\">\n
|
|
|
|
<h1 class=\"m-0\">\n<?php echo \$pageTitle; ?></h1>
|
|
|
|
</div>
|
|
|
|
<div class=\"col-sm-6\">\n
|
|
|
|
<ol class=\"breadcrumb float-sm-right\">\n
|
|
|
|
<li class=\"breadcrumb-item\">\n<a href=\"<?php echo base_url(); ?>\">\nDashboard</a></li>
|
|
|
|
<li class=\"breadcrumb-item active\">\n<?php echo \$pageTitle; ?></li>
|
|
|
|
</ol>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class=\"content\">\n
|
|
|
|
<div class=\"container-fluid\">\n
|
|
|
|
<div class=\"row\">\n
|
|
|
|
<div class=\"col\">\n
|
|
|
|
<div class=\"card card-primary card-outline\">\n
|
|
|
|
<div class=\"card-header\">\n
|
|
|
|
<h5 class=\"m-0\">\nCreate <?php echo \$pageTitle; ?> </h5>
|
|
|
|
</div>
|
|
|
|
<div class=\"card-body\">\n
|
|
|
|
<?php if(\$VoucherType->voucher_options==\"\"): ?>
|
|
|
|
<form method=POST action=\"\" enctype=\"multipart/form-data\" name=\"tbl_accounts\">\n
|
|
|
|
<div class=\"row\">\n
|
|
|
|
<div class=\"col-3\">\n
|
|
|
|
<fieldset>
|
|
|
|
<legend>Transaction Date</legend><input type=\"text\" class=\"form-control nepaliDatePicker\" id=\"voucher_date\" value=\"<?php echo NepaliDate(); ?>\" name=\"voucher_date\">\n
|
|
|
|
</fieldset>
|
|
|
|
</div>
|
|
|
|
<div class=\"col-3\">\n
|
|
|
|
<fieldset>
|
|
|
|
<?php \$DefaultAccount=\$this->myaccounts->getAccountDetails(\$VoucherType->default_account);?>
|
|
|
|
<legend><?php echo \$DefaultAccount->account_name; ?> Balance</legend><?php echo myCurrency(\$DefaultAccount->Balance); ?>
|
|
|
|
</fieldset>
|
|
|
|
</div>
|
|
|
|
<div class=\"col-3 offset-3\">\n
|
|
|
|
<fieldset>
|
|
|
|
<legend>Voucher #</legend><input type=\"text\" readonly class=\"form-control\" id=\"voucher_no\" value=\"<?php echo generateVoucherNo(); ?>\" name=\"voucher_no\">\n
|
|
|
|
</fieldset>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class=\"row\">\n
|
|
|
|
<div class=\"col\">\n
|
|
|
|
<fieldset>
|
|
|
|
<legend>Enter Transaction</legend>
|
|
|
|
<table id=\"EntryTable\" class=\"table order-list\">\n
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<td>Account</td>
|
|
|
|
<td>Narration</td>
|
|
|
|
<td>Amount</td>
|
|
|
|
<td></td>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<tr>
|
|
|
|
<td class=\"col-3\">\n <?php fillComboWithValue(\"account_id\", \"\", \"account_id\", \"tbl_accounts\", \"account_name\", \"account_id\", \"\", \"\", \"\", \"status=1\"); ?> </td>
|
|
|
|
<td class=\"col-4\">\n <input type=\"text\" name=\"narration\" id=\"narration\" class=\"form-control\" /> </td>
|
|
|
|
<td class=\"col-1\">\n <input type=\"text\" name=\"debit\" id=\"debit\" value=\"0\" class=\"form-control\" /> </td>
|
|
|
|
<td class=\"col-1\">\n <input type=\"button\" class=\"btn btn-primary full-width\" id=\"addrow\" value=\"Add\" /> </td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
<div id=\"errorBox\" class=\"alert alert-secondary hidden\" role=\"alert\">\n
|
|
|
|
<h5></h5>
|
|
|
|
</div>
|
|
|
|
</fieldset>
|
|
|
|
<div class=\"card card-primary card-outline\">\n
|
|
|
|
<div class=\"card-header\">\nTransaction List </div>
|
|
|
|
<div class=\"card-body\">\n
|
|
|
|
<table id=\"myTable\" class=\" table order-list table-striped table-bordered\">\n
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<td>Account</td>
|
|
|
|
<td>Narration</td>
|
|
|
|
<td>Amount</td>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody> </tbody>
|
|
|
|
<tfoot>
|
|
|
|
<tr>
|
|
|
|
<th colspan=\"2\" class=\"text-right\">\nTotal</th>
|
|
|
|
<td>
|
|
|
|
<div id=\"debitTotal\">\n</div>
|
|
|
|
</td>
|
|
|
|
<td>
|
|
|
|
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</tfoot>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class=\"row\">\n
|
|
|
|
<!--COL START-->
|
|
|
|
<div class=\"col\">\n
|
|
|
|
<div class=\"form-group\">\n <label for=\"remarks\">\nRemarks</label> <textarea class=\"form-control\" id=\"remarks\" name=\"remarks\">\n</textarea> </div>
|
|
|
|
</div>
|
|
|
|
<!--COL END-->
|
|
|
|
</div> <button class=\"btn btn-primary\" type=\"submit\" id=\"saveButton\" name=\"submit\">\nSave Voucher</button>
|
|
|
|
</form>
|
|
|
|
<?php else: ?>
|
|
|
|
<?php echo \$VoucherType->voucher_options; ?>
|
|
|
|
<?php endif; ?>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
|
|
\$(document).ready(function() {
|
|
|
|
var counter = 0;
|
|
|
|
\$(\"#addrow\").on(\"click\", function() {
|
|
|
|
var msg = \"Transaction Row Added !!\";
|
|
|
|
if (\$(\"#account_id\").val() != \"\") {
|
|
|
|
if (!isAccountAdded(\$(\"#account_id\").val())) {
|
|
|
|
if (\$(\"#narration\").val() != \"\") {
|
|
|
|
var debit = (\$.isNumeric(\$(\"#debit\").val()) ? \$(\"#debit\").val() : 0);
|
|
|
|
if (\$.isNumeric(debit)) {
|
|
|
|
if (debit > 0) {
|
|
|
|
addRow()
|
|
|
|
} else {
|
|
|
|
msg = \"Amount contain some value\";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
msg = \"Non numberic value entered in amount. \";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
msg = \"Narration can't be empty!\";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
msg = \"Account already added in transactions\";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
msg = \"Account Head Not Selected!\";
|
|
|
|
}
|
|
|
|
\$(\"#errorBox h5\").html(msg);
|
|
|
|
\$(\"#errorBox\").fadeTo(2000, 500).slideUp(500, function() {
|
|
|
|
\$(\"#errorBox\").slideUp(500);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
\$(\"table.order-list\").on(\"click\", \".ibtnDel\", function(event) {
|
|
|
|
\$(this).closest(\"tr\").remove();
|
|
|
|
calculateTotals();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function isAccountAdded(account_id) {
|
|
|
|
var arr = \$('input[name=\"account_id[]\"]').map(function() {
|
|
|
|
return this.value;
|
|
|
|
}).get();
|
|
|
|
if (\$.inArray(account_id, arr) >= 0) return true;
|
|
|
|
else return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function addRow() {
|
|
|
|
var newRow = \$(\"<tr>\");
|
|
|
|
var cols = \"\";
|
|
|
|
cols += '<td><input type=\"hidden\" class=\"form-control\" name=\"account_ids[]\" value=\"' + \$(\"#account_id\").val() + '\"/><input type=\"text\" readonly class=\"form-control\" name=\"account_name[]\" value=\"' + \$(\"#account_id option:selected\").text() + '\"/></td>';
|
|
|
|
cols += '<td><input type=\"text\" readonly class=\"form-control\" name=\"narration[]\" value=\"' + \$(\"#narration\").val() + '\"/></td>';
|
|
|
|
cols += '<td><input type=\"text\" readonly class=\"form-control\" name=\"debit[]\" value=\"' + (\$.isNumeric(\$(\"#debit\").val()) ? \$(\"#debit\").val() : 0) + '\"/></td>';
|
|
|
|
cols += '<td><input type=\"button\" class=\"ibtnDel btn btn-md btn-danger \" value=\"Delete\"></td>';
|
|
|
|
newRow.append(cols);
|
|
|
|
\$(\"#myTable.order-list\").append(newRow);
|
|
|
|
calculateTotals();
|
|
|
|
}
|
|
|
|
|
|
|
|
function calculateTotals() {
|
|
|
|
var debitTotal = 0;
|
|
|
|
var creditTotal = 0;
|
|
|
|
var balance = 0;
|
|
|
|
\$(\"table.order-list\").find('input[name^=\"debit[]\"]').each(function() {
|
|
|
|
debitTotal += +\$(this).val();
|
|
|
|
});
|
|
|
|
\$(\"#debit\").val(0);
|
|
|
|
\$(\"#narration\").val(\"\");
|
|
|
|
\$(\"#debitTotal\").text(debitTotal.toFixed(2));
|
|
|
|
\$(\"#balance\").text(balance.toFixed(2));
|
|
|
|
\$(\"#saveButton\").prop(\"disabled\", false);
|
|
|
|
}
|
|
|
|
\$(\"#saveButton\").prop(\"disabled\", true);
|
|
|
|
</script>";
|
|
|
|
file_put_contents($filename, $CreateFileContent);
|
|
|
|
}
|
|
|
|
private function createListView($filename)
|
|
|
|
{
|
|
|
|
$ListFileContent = "<div class=\"content-wrapper\">\n
|
|
|
|
<div class=\"content-header\">\n
|
|
|
|
<div class=\"container-fluid\">\n
|
|
|
|
<div class=\"row mb-2\">\n
|
|
|
|
<div class=\"col-sm-6\">\n
|
|
|
|
|
|
|
|
<h1 class=\"m-0\">\n<?php echo \$pageTitle; ?></h1>
|
|
|
|
</div>
|
|
|
|
<div class=\"col-sm-6\">\n
|
|
|
|
<ol class=\"breadcrumb float-sm-right\">\n
|
|
|
|
|
|
|
|
<li class=\"breadcrumb-item\">\n<a href=\"<?php echo base_url(); ?>\">\nDashboard</a></li>
|
|
|
|
<li class=\"breadcrumb-item active\">\n<?php echo \$pageTitle; ?></li>
|
|
|
|
|
|
|
|
</ol>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class=\"content\">\n
|
|
|
|
<div class=\"container-fluid\">\n
|
|
|
|
<div class=\"row\">\n
|
|
|
|
<div class=\"col\">\n
|
|
|
|
|
|
|
|
<div class=\"card card-primary card-outline\">\n
|
|
|
|
<div class=\"card-header\">\n
|
|
|
|
|
|
|
|
<h5 class=\"m-0\">\n<?php echo \$pageTitle; ?> <a href=\"<?php echo site_url(\"accounts/vouchers/\".\$VoucherType->voucher_alias.\"/create\"); ?>\" class=\"btn btn-sm btn-primary float-right\">\nCreate New <?php echo \$pageTitle; ?></a></h5>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class=\"card-body\">\n
|
|
|
|
|
|
|
|
<?php \$TableData = \$Vouchers ?>
|
|
|
|
|
|
|
|
<table class=\"table table-bordered table-striped\" id=\"voucherList\">\n
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>ID#</th>
|
|
|
|
<th>Voucher No</th>
|
|
|
|
<th>Voucher Date</th>
|
|
|
|
|
|
|
|
<th>Voucher Type</th>
|
|
|
|
<th>Voucher State</th>
|
|
|
|
|
|
|
|
<th class=\"table-col col-2\">Action</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<?php foreach (\$TableData as \$TableRow) : ?>
|
|
|
|
<?php foreach (\$TableRow as \$cols) : \$id = \$cols;
|
|
|
|
break;
|
|
|
|
endforeach; ?><tr data-id=\"<?php echo \$TableRow->voucher_id; ?>\" class=\"<?php echo(\$TableRow->voucher_state==\"Reversed\")?\"table-danger\":\"\"; ?>\">\n
|
|
|
|
<td><?php echo \$TableRow->voucher_id; ?></td>
|
|
|
|
<td><?php echo \$TableRow->voucher_no; ?></td>
|
|
|
|
|
|
|
|
<td><?php echo \$TableRow->voucher_date; ?></td>
|
|
|
|
|
|
|
|
<td><?php echo \$TableRow->voucher_type; ?></td>
|
|
|
|
<td><?php echo \$TableRow->voucher_state; ?></td>
|
|
|
|
|
|
|
|
<td class=\"col-1\">\n
|
|
|
|
<a onClick=\"javascript:showDetails(<?php echo \$id; ?>);\" class=\"btn btn-success btn-xs\" title=\"View Details\">\n<i class=\"fa fa-eye\">\n</i></a>
|
|
|
|
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<?php endforeach; ?>
|
|
|
|
<tbody>
|
|
|
|
</table>
|
|
|
|
<div class=\"modal fade\" id=\"voucherdetails_box\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"voucherdetails_box\" aria-hidden=\"true\">\n
|
|
|
|
<div class=\"modal-dialog modal-xl\" role=\"document\">\n
|
|
|
|
<div class=\"modal-content\">\n
|
|
|
|
<div class=\"modal-header\">\n
|
|
|
|
<h5 class=\"modal-title\" id=\"exampleModalLabel\">\nVoucher Details</h5>
|
|
|
|
<button type=\"button\" class=\"close\" data-dismiss=\"modal\" aria-label=\"Close\">\n
|
|
|
|
<span aria-hidden=\"true\">\n×</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div class=\"modal-body\" id=\"details_container\">\n
|
|
|
|
Voucher Details Goes Here
|
|
|
|
</div>
|
|
|
|
<div class=\"modal-footer\">\n
|
|
|
|
<button type=\"button\" onClick='reversalEntry()' id=\"reversalBtn\" class=\"btn btn-secondary\" data-dismiss=\"modal\" data-id=\"\">\nRevarsal Entry</button>
|
|
|
|
<button type=\"button\" class=\"btn btn-secondary\" data-dismiss=\"modal\">\nClose</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
|
|
function showDetails(id) {
|
|
|
|
\$.ajax({
|
|
|
|
url: \"<?php echo site_url(\"accounts/vouchers/voucherdetails/\"); ?>\" + id,
|
|
|
|
success: function(data) {
|
|
|
|
\$(\"#details_container\").html(data);
|
|
|
|
\$(\"#reversalBtn\").data(\"id\",id);
|
|
|
|
\$(\"#voucherdetails_box\").modal('show');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
function reversalEntry()
|
|
|
|
{
|
|
|
|
var id=\$(\"#reversalBtn\").data(\"id\");
|
|
|
|
|
|
|
|
if(confirm(\"Are you sure you want to post reversal for this voucher?\"))
|
|
|
|
{
|
|
|
|
window.location=\"<?php echo site_url(\"accounts/vouchers/reversal/\"); ?>\"+id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php
|
|
|
|
function footerfunctions()
|
|
|
|
{
|
|
|
|
?>
|
|
|
|
<script>
|
|
|
|
\$(document).ready(function() {
|
|
|
|
var table = \$('#voucherList').DataTable();
|
|
|
|
|
|
|
|
var tableRows = \$('table#voucherList tbody').find('tr');
|
|
|
|
tableRows.each(function() {
|
|
|
|
async: false;
|
|
|
|
var jqueryRow = \$(this);
|
|
|
|
var row = table.row(jqueryRow);
|
|
|
|
var id=\$(this).data(\"id\");
|
|
|
|
var Transactions=\"<table class='table table-resonsive'><tr><th>Account<\/th><th>Narration<\/th><th>Dr<\/th><th>Cr<\/th><\/tr><tr><td>Billable Projects<\/td><td>Website Development<\/td><td>50000<\/td><td>0<\/td><\/tr><tr><td>Larke Himal Jadibuti Udhyog<\/td><td>Website Development<\/td><td>0<\/td><td>50000<\/td><\/tr><\/table>\";
|
|
|
|
Transactions=getVoucherDetails(id);
|
|
|
|
row.child(Transactions).show();
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
function getVoucherDetails(id) {
|
|
|
|
\$.data;
|
|
|
|
\$.ajax({
|
|
|
|
url: \"<?php echo site_url(\"ajax/getVoucherDetailsTable/\"); ?>\" + id,
|
|
|
|
async: false,
|
|
|
|
success: function(data) {
|
|
|
|
\$.data=data;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return (\$.data);
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
?>";
|
|
|
|
file_put_contents($filename, $ListFileContent);
|
|
|
|
}
|
2024-07-16 12:43:55 +05:45
|
|
|
function checkifAccountExists($account_name)
|
|
|
|
{
|
|
|
|
return ($this->db->query("select * from tbl_accounts where UPPER(account_name)='" . strtoupper($account_name) . "'")->num_rows() > 0) ? true : false;
|
|
|
|
}
|
2024-07-10 18:28:19 +05:45
|
|
|
}
|