2024-07-10 18:28:19 +05:45
|
|
|
<?php
|
|
|
|
defined('BASEPATH') or exit('No direct script access allowed');
|
|
|
|
class Purchases extends CI_Controller
|
|
|
|
{
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
$this->load->model('MStocks');
|
|
|
|
$this->load->model('MPurchases');
|
|
|
|
checkLogin();
|
|
|
|
}
|
|
|
|
public function _remap($alias = "", $params = array())
|
|
|
|
{
|
|
|
|
|
|
|
|
$data['dataValue'] = $this->session;
|
|
|
|
|
|
|
|
$data['pageTitle'] = "Purchase";
|
|
|
|
|
|
|
|
switch ($alias) {
|
|
|
|
case 'details':
|
|
|
|
$id = $this->uri->segment(4);
|
|
|
|
$this->db->where('purchase_id', $id);
|
|
|
|
$data['Purchase'] = $this->db->get("tbl_purchases")->row();
|
|
|
|
$this->db->where('purchases_id', $id);
|
|
|
|
$data['PurchaseDetails'] = $this->db->get("tbl_purchasedetails")->result();
|
|
|
|
$data['pageTitle'] = "View Purchase";
|
2024-08-06 12:48:20 +05:45
|
|
|
// print_r($data);die;
|
2024-07-10 18:28:19 +05:45
|
|
|
loadView("inventory/purchases/view", $data);
|
|
|
|
break;
|
|
|
|
case 'create':
|
|
|
|
// print_r($_POST);die;
|
|
|
|
if (isset($_POST['accounts_id'])) {
|
|
|
|
$TableData = array(
|
|
|
|
'transaction_type' => "Purchase Entry",
|
|
|
|
'accounts_id' => filter_var($_POST['accounts_id']),
|
|
|
|
'purchase_date' => filter_var($_POST['purchase_date']),
|
2024-07-16 12:43:55 +05:45
|
|
|
'discount' => filter_var($_POST['discountpercentage']),
|
2024-07-10 18:28:19 +05:45
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
2024-08-06 12:48:20 +05:45
|
|
|
'vatToggle' => filter_var($_POST['vatToggleValue']),
|
2024-07-10 18:28:19 +05:45
|
|
|
'created_by' => 'admin',
|
|
|
|
'remarks' => '',
|
|
|
|
'status' => 1,
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_purchases', $TableData);
|
|
|
|
$purchase_id = $this->db->insert_id();
|
|
|
|
$a = 0;
|
|
|
|
foreach ($_POST['item_id'] as $item) {
|
|
|
|
$TableData = array(
|
|
|
|
'purchases_id' => $purchase_id,
|
|
|
|
'items_id' => $item,
|
|
|
|
'qty' => $_POST['quantity'][$a],
|
|
|
|
'rate' => $_POST['rate'][$a],
|
2024-10-08 15:47:07 +05:45
|
|
|
'vat' => $_POST['vat'][$a],
|
2024-07-10 18:28:19 +05:45
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => 'admin',
|
|
|
|
'remarks' => '',
|
|
|
|
'status' => 1,
|
|
|
|
);
|
|
|
|
$this->db->insert('tbl_purchasedetails', $TableData);
|
|
|
|
$a += 1;
|
|
|
|
}
|
|
|
|
$this->MStocks->addPurchaseToStock($this->db->where("purchases_id", $purchase_id)->get("tbl_purchasedetails")->result());
|
|
|
|
redirect("inventory/purchases/list");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'add':
|
|
|
|
//
|
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
|
|
|
if (isset($_POST['submit'])) {
|
|
|
|
$TableData = array(
|
|
|
|
'transaction_type' => filter_var($_POST['transaction_type']),
|
|
|
|
'accounts_id' => filter_var($_POST['accounts_id']),
|
|
|
|
'purchase_date' => filter_var($_POST['purchase_date']),
|
|
|
|
'created_on' => date('Y-m-d H:i:s'),
|
|
|
|
'created_by' => 'admin',
|
|
|
|
'remarks' => filter_var($_POST['remarks']),
|
|
|
|
'status' => 1,
|
|
|
|
);
|
2024-10-17 17:06:13 +05:45
|
|
|
// pre($_POST);
|
|
|
|
// die;
|
2024-07-10 18:28:19 +05:45
|
|
|
//$this->db->insert('tbl_purchases', $TableData);
|
|
|
|
redirect("inventory/purchases/list");
|
|
|
|
}
|
|
|
|
loadView("inventory/purchases/create", $data);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'delete':
|
|
|
|
$id = $this->uri->segment(4);
|
|
|
|
$this->db->where('purchase_id', $id);
|
|
|
|
$this->db->delete('tbl_purchases');
|
|
|
|
$this->db->where('purchases_id', $id);
|
|
|
|
$this->db->delete('tbl_purchasedetails');
|
|
|
|
redirect("inventory/purchases/list");
|
|
|
|
break;
|
2024-10-17 17:06:13 +05:45
|
|
|
case 'purchase_register':
|
|
|
|
if (!isset($_POST['fromDate'])) {
|
|
|
|
$data['fromDate'] = null;
|
|
|
|
}
|
|
|
|
if (!isset($_POST['toDate'])) {
|
|
|
|
$data['toDate'] = null;
|
|
|
|
}
|
|
|
|
if (isset($_POST)) {
|
|
|
|
$data = $_POST;
|
|
|
|
}
|
|
|
|
$data['fiscalStart'] = NepaliToEnglishDate($data['fromDate'] ?? $this->session->userdata['FiscalYear']->fiscalyear_from);
|
|
|
|
$data['fiscalEnd'] = NepaliToEnglishDate($data['toDate'] ?? $this->session->userdata['FiscalYear']->fiscalyear_to);
|
|
|
|
$data['pageTitle'] = "Sales & Register";
|
|
|
|
|
|
|
|
|
|
|
|
$data['PurchaseRecords'] = $this->MPurchases->getPurchaseRecords($data['fiscalStart'],$data['fiscalEnd']);
|
2024-07-10 18:28:19 +05:45
|
|
|
loadView("inventory/purchases/register", $data);
|
2024-07-12 17:57:29 +05:45
|
|
|
break;
|
2024-07-16 12:43:55 +05:45
|
|
|
|
|
|
|
case 'getunitbyitem':
|
|
|
|
$id = $this->uri->segment(4);
|
|
|
|
$unit = $this->MStocks->getUnitByItemId($id);
|
|
|
|
echo json_encode($unit);
|
|
|
|
break;
|
|
|
|
|
2024-07-10 18:28:19 +05:45
|
|
|
default:
|
|
|
|
$data['PurchaseRecords'] = $this->MPurchases->getPurchaseRecords();
|
|
|
|
loadView("inventory/purchases/list", $data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|