D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home
/
ksclnmuac
/
public_html
/
cas
/
application
/
controllers
/
admin
/
Filename :
Fee.php
back
Copy
<?php /** * Controller For Handling All Requests Related To Fee * * @author Softpro India Pvt. Ltd. */ defined('BASEPATH') OR exit('No direct script access allowed'); class Fee extends CI_Controller { public function __construct() { parent::__construct(); $this->load->model('admin/FeeManagement'); $this->load->model('admin/SessionManagement'); $this->load->model('admin/CourseManagement'); $this->load->model('admin/BranchManagement'); $this->load->model('admin/StudentManagement'); $this->load->model('admin/HostelManagement'); $this->load->library('util/Denominator'); } public function index() { redirect("admin/Fee/receiptManagement"); } /* Request Handlers For Fee Collection */ public function collectFeeOld($tspi_id = '') { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $error = ""; $studentData = array(); $feeInfo = array(); $alreadyPaidFee = array(); if (isset($_POST['fetchStudentInfo']) || $tspi_id != "") { $formEnrlRollNo = addslashes(trim($this->input->post('formEnrlRollNo'))); if ($formEnrlRollNo != "" || $tspi_id != "") { $this->session->set_flashdata('errorMessage', NULL); if ($tspi_id != "") { $studentData = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($tspi_id)->result(); } else { $studentData = $this->StudentManagement->getStudentInfoByFormEnrollmentOrRollNo($formEnrlRollNo)->result(); } if (sizeof($studentData)) { $student_info = $studentData[0]; $is_structure_set = (sizeof($this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id)->result())) ? true : false; $studentFatherName = $this->StudentManagement->getStudentFatherInfoBy($student_info->tspi_id)->result()[0]->tfbi_name; $studentCurrentSemesterInfo = $this->StudentManagement->getStudentCurrentSectionSemesterInfoBy($student_info->tspi_id)->result(); $gender = ""; $studentCurrentSemesterOrYear = ""; $semesterOrYearToShow = ""; $timeMgmtFlag = ($student_info->course_time_mgmt_flag == "S") ? "Sem." : "Year"; $entryType = stripslashes($student_info->tcsm_course_type); $totalSemestersOrYears = $student_info->course_no_of_sems; $isFirstPayment = FALSE; if ($student_info->tspi_gender == "M") { $gender = "<i class='fa fa-male'></i>|Male"; } else if ($student_info->tspi_gender == "F") { $gender = "<i class='fa fa-female'></i>|Female"; } else { $gender = "<i class='fa fa-transgender'></i>|Transgender"; } if (sizeof($studentCurrentSemesterInfo)) { $studentCurrentSemesterOrYear = $studentCurrentSemesterInfo[0]->tsssi_semester; $semesterOrYearToShow = $studentCurrentSemesterOrYear; $paidFeeInfo = $this->FeeManagement->getAllPaidFeeDetailsBy($student_info->tspi_id)->result(); if (sizeof($paidFeeInfo) == 0) { $isFirstPayment = TRUE; if ($entryType == "Lateral Entry") { $studentCurrentSemesterOrYear = 3; } else { $studentCurrentSemesterOrYear = 1; } } else { $studentCurrentSemesterOrYear = $paidFeeInfo[0]->fcm_semester; } } else { $studentCurrentSemesterOrYear = $student_info->tcsm_sem_start_from; $semesterOrYearToShow = "New Admission"; $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsBy($student_info->tspi_id, $studentCurrentSemesterOrYear)->result(); if (!sizeof($paidFeeInfo)) { $isFirstPayment = TRUE; } } $studentData = array( 'stu_id' => $student_info->tspi_id, 'stu_name' => stripslashes($student_info->tspi_name), 'stu_father_name' => stripslashes($studentFatherName), 'stu_gender' => $gender, 'stu_form_no' => stripslashes($student_info->tspi_form_no), 'stu_roll_no' => ($student_info->tspi_form_no == $student_info->tspi_rollNumber) ? "-" : stripslashes($student_info->tspi_rollNumber), 'stu_enrollment_no' => ($student_info->tspi_form_no == $student_info->tspi_enrollment_no) ? "-" : stripslashes($student_info->tspi_enrollment_no), 'stu_dob' => date('d-m-Y', strtotime($student_info->tspi_dob)), 'stu_category' => stripslashes($student_info->tspi_category), 'stu_course' => stripslashes($student_info->course_name), 'stu_entry_type' => $entryType, 'stu_session' => stripslashes($student_info->session_name), 'stu_batch' => explode('-', $student_info->session_name)[0] . "-" . $student_info->session_end_year, 'stu_photograph' => base_url("assets/admin/uploads/studentData/") . $student_info->studentPhoto, 'stu_sign' => base_url("assets/admin/uploads/studentData/") . $student_info->studentSign, 'stu_sch_eligible' => ($student_info->tspi_scholarship_eligible == "T") ? "Yes (" . $student_info->tspi_scholarship_percentage . "%)" : "Not Eligible", 'stu_current_semester' => $semesterOrYearToShow, 'stu_fee_structure_avail' => $is_structure_set ); /* Fetching And Setting Fee Info */ if ($isFirstPayment) { $eligibleStructureForPayment = $this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id)->result(); if (sizeof($eligibleStructureForPayment)) { for ($i = 0; $i < sizeof($eligibleStructureForPayment); $i++) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . 0.0 . "/-", 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_due_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'paying_for_year_sem' => $eligibleStructureForPayment[$i]->fssm_semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => array(), 'is_field_enabled' => TRUE, 'is_first_payment' => TRUE )); } } else { $error = "Fee Has Not Been Setup For This Course, Session & Semester/Year. Please Ask Admin To Setup Fee Details."; } } else { $allPaidFeeDetails = $this->FeeManagement->getAllPaidFeeDetailsBy($student_info->tspi_id)->result(); $firstPaidSemesterOrYear = $allPaidFeeDetails[0]->fcm_semester; $cousellingFeeInfo = $this->FeeManagement->getPaidCouncellingFeeDetailsByStudent($student_info->tspi_id)->result(); $ifCounsellingFeeAdjusted = FALSE; for ($semester = $firstPaidSemesterOrYear; $semester <= $totalSemestersOrYears; $semester++) { $eligibleStructureForPayment = $this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id, $semester)->result(); $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsBy($student_info->tspi_id, $semester)->result(); if (sizeof($eligibleStructureForPayment)) { for ($i = 0; $i < sizeof($eligibleStructureForPayment); $i++) { $paidFeeInfoByStructure = $this->FeeManagement->getPaidFeeDetailsByStructure($student_info->tspi_id, $semester, $eligibleStructureForPayment[$i]->fssm_id)->result(); if (sizeof($paidFeeInfoByStructure)) { $paidAmount = 0.0; for ($j = 0; $j < sizeof($paidFeeInfoByStructure); $j++) { $paidAmount += $paidFeeInfoByStructure[$j]->fcm_amount; } $applicableAmount = $eligibleStructureForPayment[$i]->fssm_amount; /* C.F. Adjustment */ $settlement = ""; if ($ifCounsellingFeeAdjusted == FALSE && $eligibleStructureForPayment[$i]->fhm_type == "R" && sizeof($cousellingFeeInfo)) { if (($paidAmount + $cousellingFeeInfo[0]->fcnm_amount) <= $applicableAmount) { $paidAmount += $cousellingFeeInfo[0]->fcnm_amount; $settlement = " (<i class='fa fa-inr'></i>" . $cousellingFeeInfo[0]->fcnm_amount . " C.F. Adj.)"; $ifCounsellingFeeAdjusted = TRUE; } } /* C.F. Adjustment */ if ($paidAmount == 0.0) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-", 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => TRUE, 'is_first_payment' => FALSE )); } else if ($paidAmount < $applicableAmount) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-" . $settlement, 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => (round(($applicableAmount - $paidAmount), 2) == 0 ) ? FALSE : TRUE, 'is_first_payment' => FALSE )); } else { array_push($alreadyPaidFee, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-" . $settlement, 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => (round(($applicableAmount - $paidAmount), 2) <= 0) ? FALSE : TRUE, 'is_first_payment' => FALSE )); } } else { $paidAmount = 0.0; if ($eligibleStructureForPayment[$i]->fhm_type == "R" && $ifCounsellingFeeAdjusted == FALSE) { if (sizeof($cousellingFeeInfo)) { $paidAmount = $cousellingFeeInfo[0]->fcnm_amount; } $ifCounsellingFeeAdjusted = TRUE; } array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-", 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($eligibleStructureForPayment[$i]->fssm_amount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($eligibleStructureForPayment[$i]->fssm_amount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => TRUE, 'is_first_payment' => FALSE )); } } } else { $error = "Next Due Fees Has Not Been Setup. Please Ask Admin To Setup Fee Details."; break; } } } } else { $error = "No Student Data Found Against The Entered Form No./Enrl. No./Roll No."; } } else { $this->session->set_flashdata('errorMessage', "Enter Form No./Enrl. No./Roll No. Of Student."); $studentData = array(); $feeInfo = array(); } } $finalArray = array(); for ($i = 0; $i < sizeof($alreadyPaidFee); $i++) { array_push($finalArray, $alreadyPaidFee[$i]); } for ($i = 0; $i < sizeof($feeInfo); $i++) { array_push($finalArray, $feeInfo[$i]); } $viewData['error'] = $error; $viewData['studentInfo'] = $studentData; $viewData['feeInfo'] = $finalArray; $viewData['sessions'] = $this->SessionManagement->getNonDeletedActiveSessions(array('O', 'C'))->result(); $viewData['feeModes'] = $this->FeeManagement->getNonDeletedActiveFeeModes()->result(); $this->load->view('admin/fee/collectFeeOld', $viewData); } else { redirect("admin/"); } } public function saveFeeAndGenerateReceiptOld() { if ($this->sessionvalidator->isLoggedIn()) { $studentInfo = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy(trim($this->input->post('tspi_id')))->result()[0]; $councellingFeeInfo = array(); /* Handling Councelling Fee */ if ($this->input->post('paidCouncellingFee') != NULL) { $councellingFeeAmt = $this->input->post('councellingFeeAmt'); $councellingFeeMode = $this->input->post('councellingFeeMode'); $councellingFeeRefNo = $this->input->post('councellingChDDTxnNRFN'); $councellingFeeDate = date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('councellingFeePaymentDate')))); $councellingFeeInfo = array( 'fcnm_amount' => $councellingFeeAmt, 'fcnm_mode' => $councellingFeeMode, 'fcnm_ref_no' => $councellingFeeRefNo, 'fcnm_date' => $councellingFeeDate, 'frm_id' => '', 'tspi_id' => trim($this->input->post('tspi_id')), 'fcnm_added_on' => date("Y-m-d H:i:s"), 'fcnm_added_by' => $this->session->userdata("adminData")["smember_id"], 'fcnm_updated_on' => date("Y-m-d H:i:s"), 'fcnm_updated_by' => $this->session->userdata("adminData")["smember_id"] ); } /* Handling Councelling Fee */ /* Handling Compulsory Fee Against The Selected Heads */ $collectionInfo = array(); $partPaymentInfo = array(); $fssmIds = $this->input->post("selectedFssmIds"); if (is_array($fssmIds) || is_object($fssmIds)) { foreach ($fssmIds as $fssmId) { $valueOfI = $this->input->post("fssm" . $fssmId); array_push($collectionInfo, array( 'fcm_txn_id_ref_dd_ch_no' => trim($this->input->post('chDDTxnNRFN')), 'fcm_txn_id_ref_dd_ch_date' => date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))), 'fcm_bank_name' => addslashes(trim($this->input->post('bankName'))), 'fcm_semester' => $this->input->post("payingForSemOrYear[$fssmId]"), 'fcm_amount' => $this->input->post("submittedAmt[$valueOfI]"), 'session_id' => $this->input->post("sessions[$fssmId]"), 'fcm_entry_on' => date("Y-m-d H:i:s"), 'tspi_id' => trim($this->input->post('tspi_id')), 'fssm_id' => $fssmId, 'fmm_id' => trim($this->input->post('feeMode')), 'frm_id' => '' )); array_push($partPaymentInfo, array( 'fssm_id' => $fssmId, 'is_part_payment' => ($this->input->post("submittedAmt[$valueOfI]") < $this->input->post("fssm_amounts[$fssmId]")) ? true : false )); } } /* Handling Compulsory Fee Against The Selected Heads */ /* Handling Fee Receipt Info */ $newFeeReceiptInfo = array( 'frm_receipt_date' => date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('feeReceiptDate')))), 'frm_receipt_no' => trim($this->input->post('feeReceiptNo')), 'frm_total_amount' => trim($this->input->post("totalFeeCollected")), 'frm_remarks' => addslashes(trim($this->input->post('remarks'))), 'frm_title' => addslashes(trim($this->input->post('receiptTitle'))), 'frm_generated_on' => date("Y-m-d H:i:s"), 'frm_generated_by' => $this->session->userdata("adminData")["smember_id"], 'frm_updated_on' => date("Y-m-d H:i:s"), 'frm_updated_by' => $this->session->userdata("adminData")["smember_id"] ); $this->db->trans_start(); $frm_id = $this->FeeManagement->createNewReceipt($newFeeReceiptInfo); for ($i = 0; $i < sizeof($collectionInfo); $i++) { $collectionInfo[$i]['frm_id'] = $frm_id; } $this->FeeManagement->createFeeCollectionInfoMulti($collectionInfo); if (sizeof($councellingFeeInfo)) { $councellingFeeInfo['frm_id'] = $frm_id; $this->FeeManagement->createNewCouncellingFee($councellingFeeInfo); } $this->db->trans_complete(); /* Handling Fee Receipt Info & Making Entries */ /* Setting Data For Fee Receipt */ $chqDDTxnNEFTRefNo = trim($this->input->post('chDDTxnNRFN')); $chqDDTxnNEFTDate = date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))); $totalPaid = trim($this->input->post("totalFeeCollected")); $paymentModeInfo = $this->FeeManagement->getFeeModeInfoBy(trim($this->input->post('feeMode')))->result()[0]; $councellingFeePaymentModeInfo = ""; $councellingFeeDate = ""; $councellingFeeAmt = ""; $coucellingRefNo = ""; if (sizeof($councellingFeeInfo)) { $councellingFeePaymentModeInfo = $this->FeeManagement->getFeeModeInfoBy(trim($this->input->post('councellingFeeMode')))->result()[0]; $councellingFeeDate = date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('councellingFeePaymentDate')))); $councellingFeeAmt = trim($this->input->post('councellingFeeAmt')); $coucellingRefNo = trim($this->input->post('councellingChDDTxnNRFN')); } $collectionInfoDetails = array(); for ($i = 0; $i < sizeof($collectionInfo); $i++) { $feeStructureInfo = $this->FeeManagement->getFeeStructureDetailsOfStudentById($collectionInfo[$i]['fssm_id'])->result()[0]; array_push($collectionInfoDetails, array( 'fee_head' => stripslashes($feeStructureInfo->fhm_short_name), 'amount_paid' => "INR(<i class='fa fa-inr'></i>) " . $collectionInfo[$i]['fcm_amount'] . "/-", 'sem_or_year' => $collectionInfo[$i]['fcm_semester'], 'is_part_payment' => ($partPaymentInfo[$i]['is_part_payment']) ? "(Partial Payment)" : "" )); } $receiptData = array( 'receipt_title' => addslashes(trim($this->input->post('receiptTitle'))), 'receipt_number' => trim($this->input->post('feeReceiptNo')), 'receipt_date' => date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('feeReceiptDate')))), 'student_details' => $studentInfo, 'fee_mode' => stripslashes($paymentModeInfo->fmm_short_name), 'chqDDTxnNEFTRefNo' => $chqDDTxnNEFTRefNo, 'chqDDTxnNEFTDate' => (!strcasecmp(stripslashes($paymentModeInfo->fmm_short_name), "cash")) ? "NA" : $chqDDTxnNEFTDate, 'total_paid' => $totalPaid, 'total_paid_in_words' => $this->denominator->convertToWords($totalPaid), 'councelling_fee' => $councellingFeeInfo, 'councelling_amount' => $councellingFeeAmt, 'councelling_fee_mode' => (is_object($councellingFeePaymentModeInfo)) ? stripslashes($councellingFeePaymentModeInfo->fmm_short_name) : "", 'councelling_fee_ref_no' => $coucellingRefNo, 'councelling_fee_date' => $councellingFeeDate, 'collection_info' => $collectionInfoDetails, 'is_old_fee' => TRUE, 'is_cancelled' => FALSE ); $this->session->set_flashdata('successMessage', 'Fee Collection Details Saved Successfully.'); $this->load->view("admin/fee/receipt", $receiptData); } else { redirect("admin/"); } } public function collectFee($tspi_id = '') { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $error = ""; $studentData = array(); $feeInfo = array(); $alreadyPaidFee = array(); if (isset($_POST['fetchStudentInfo']) || $tspi_id != "") { $formEnrlRollNo = addslashes(trim($this->input->post('formEnrlRollNo'))); if ($formEnrlRollNo != "" || $tspi_id != "") { $this->session->set_flashdata('errorMessage', NULL); if ($tspi_id != "") { $studentData = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($tspi_id)->result(); } else { $studentData = $this->StudentManagement->getStudentInfoByFormEnrollmentOrRollNo($formEnrlRollNo)->result(); } if (sizeof($studentData)) { $student_info = $studentData[0]; $is_structure_set = (sizeof($this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id)->result())) ? true : false; $studentFatherName = $this->StudentManagement->getStudentFatherInfoBy($student_info->tspi_id)->result()[0]->tfbi_name; $studentCurrentSemesterInfo = $this->StudentManagement->getStudentCurrentSectionSemesterInfoBy($student_info->tspi_id)->result(); $gender = ""; $studentCurrentSemesterOrYear = ""; $semesterOrYearToShow = ""; $timeMgmtFlag = ($student_info->course_time_mgmt_flag == "S") ? "Sem." : "Year"; $entryType = stripslashes($student_info->tcsm_course_type); $totalSemestersOrYears = $student_info->course_no_of_sems; $isFirstPayment = FALSE; if ($student_info->tspi_gender == "M") { $gender = "<i class='fa fa-male'></i>|Male"; } else if ($student_info->tspi_gender == "F") { $gender = "<i class='fa fa-female'></i>|Female"; } else { $gender = "<i class='fa fa-transgender'></i>|Transgender"; } if (sizeof($studentCurrentSemesterInfo)) { $studentCurrentSemesterOrYear = $studentCurrentSemesterInfo[0]->tsssi_semester; $semesterOrYearToShow = $studentCurrentSemesterOrYear; $paidFeeInfo = $this->FeeManagement->getAllPaidFeeDetailsBy($student_info->tspi_id)->result(); if (sizeof($paidFeeInfo) == 0) { $isFirstPayment = TRUE; if ($entryType == "Lateral Entry") { $studentCurrentSemesterOrYear = 3; } else { $studentCurrentSemesterOrYear = 1; } } else { $studentCurrentSemesterOrYear = $paidFeeInfo[0]->fcm_semester; } } else { $studentCurrentSemesterOrYear = $student_info->tcsm_sem_start_from; $semesterOrYearToShow = "New Admission"; $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsBy($student_info->tspi_id, $studentCurrentSemesterOrYear)->result(); if (!sizeof($paidFeeInfo)) { $isFirstPayment = TRUE; } } $studentData = array( 'stu_id' => $student_info->tspi_id, 'stu_name' => stripslashes($student_info->tspi_name), 'stu_father_name' => stripslashes($studentFatherName), 'stu_gender' => $gender, 'stu_form_no' => stripslashes($student_info->tspi_form_no), 'stu_roll_no' => ($student_info->tspi_form_no == $student_info->tspi_rollNumber) ? "-" : stripslashes($student_info->tspi_rollNumber), 'stu_enrollment_no' => ($student_info->tspi_form_no == $student_info->tspi_enrollment_no) ? "-" : stripslashes($student_info->tspi_enrollment_no), 'stu_dob' => date('d-m-Y', strtotime($student_info->tspi_dob)), 'stu_category' => stripslashes($student_info->tspi_category), 'stu_course' => stripslashes($student_info->course_name), 'stu_entry_type' => $entryType, 'stu_session' => stripslashes($student_info->session_name), 'stu_batch' => explode('-', $student_info->session_name)[0] . "-" . $student_info->session_end_year, 'stu_photograph' => base_url("assets/admin/uploads/studentData/") . $student_info->studentPhoto, 'stu_sign' => base_url("assets/admin/uploads/studentData/") . $student_info->studentSign, 'stu_sch_eligible' => ($student_info->tspi_scholarship_eligible == "T") ? "Yes (" . $student_info->tspi_scholarship_percentage . "%)" : "Not Eligible", 'stu_current_semester' => $semesterOrYearToShow, 'stu_fee_structure_avail' => $is_structure_set ); /* Fetching And Setting Fee Info */ if ($isFirstPayment) { $eligibleStructureForPayment = $this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id)->result(); if (sizeof($eligibleStructureForPayment)) { for ($i = 0; $i < sizeof($eligibleStructureForPayment); $i++) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . 0.0 . "/-", 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_due_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'paying_for_year_sem' => $eligibleStructureForPayment[$i]->fssm_semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => array(), 'is_field_enabled' => TRUE, 'is_first_payment' => TRUE )); } } else { $error = "Fee Has Not Been Setup For This Course, Session & Semester/Year. Please Ask Admin To Setup Fee Details."; } } else { $allPaidFeeDetails = $this->FeeManagement->getAllPaidFeeDetailsBy($student_info->tspi_id)->result(); $firstPaidSemesterOrYear = $allPaidFeeDetails[0]->fcm_semester; $cousellingFeeInfo = $this->FeeManagement->getPaidCouncellingFeeDetailsByStudent($student_info->tspi_id)->result(); $ifCounsellingFeeAdjusted = FALSE; for ($semester = $firstPaidSemesterOrYear; $semester <= $totalSemestersOrYears; $semester++) { $eligibleStructureForPayment = $this->FeeManagement->getFeeStructureOfStudentBy($student_info->tspi_id, $semester)->result(); $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsBy($student_info->tspi_id, $semester)->result(); if (sizeof($eligibleStructureForPayment)) { for ($i = 0; $i < sizeof($eligibleStructureForPayment); $i++) { $paidFeeInfoByStructure = $this->FeeManagement->getPaidFeeDetailsByStructure($student_info->tspi_id, $semester, $eligibleStructureForPayment[$i]->fssm_id)->result(); if (sizeof($paidFeeInfoByStructure)) { $paidAmount = 0.0; for ($j = 0; $j < sizeof($paidFeeInfoByStructure); $j++) { $paidAmount += $paidFeeInfoByStructure[$j]->fcm_amount; } $applicableAmount = $eligibleStructureForPayment[$i]->fssm_amount; /* C.F. Adjustment */ $settlement = ""; if ($ifCounsellingFeeAdjusted == FALSE && $eligibleStructureForPayment[$i]->fhm_type == "R" && sizeof($cousellingFeeInfo)) { if (($paidAmount + $cousellingFeeInfo[0]->fcnm_amount) <= $applicableAmount) { $paidAmount += $cousellingFeeInfo[0]->fcnm_amount; $settlement = " (<i class='fa fa-inr'></i>" . $cousellingFeeInfo[0]->fcnm_amount . " C.F. Adj.)"; $ifCounsellingFeeAdjusted = TRUE; } } /* C.F. Adjustment */ if ($paidAmount == 0.0) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-", 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => TRUE, 'is_first_payment' => FALSE )); } else if ($paidAmount < $applicableAmount) { array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-" . $settlement, 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => (round(($applicableAmount - $paidAmount), 2) == 0) ? FALSE : TRUE, 'is_first_payment' => FALSE )); } else { array_push($alreadyPaidFee, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $applicableAmount . "/-", 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-" . $settlement, 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($applicableAmount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($applicableAmount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => (round(($applicableAmount - $paidAmount), 2) <= 0) ? FALSE : TRUE, 'is_first_payment' => FALSE )); } } else { $paidAmount = 0.0; if ($eligibleStructureForPayment[$i]->fhm_type == "R" && $ifCounsellingFeeAdjusted == FALSE) { if (sizeof($cousellingFeeInfo)) { $paidAmount = $cousellingFeeInfo[0]->fcnm_amount; } } array_push($feeInfo, array( 'fhm_id' => $eligibleStructureForPayment[$i]->fhm_id, 'fssm_id' => $eligibleStructureForPayment[$i]->fssm_id, 'fhm_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_name), 'fhm_short_name' => stripslashes($eligibleStructureForPayment[$i]->fhm_short_name), 'fhm_type' => $eligibleStructureForPayment[$i]->fhm_type, 'fhm_calculation' => $eligibleStructureForPayment[$i]->fhm_calculation, 'fssm_amount' => "<i class='fa fa-inr'></i> " . $eligibleStructureForPayment[$i]->fssm_amount . "/-", 'fssm_paid_amount' => "<i class='fa fa-inr'></i> " . $paidAmount . "/-", 'fssm_amount_hidden' => $eligibleStructureForPayment[$i]->fssm_amount, 'fssm_due_amount' => "<i class='fa fa-inr'></i> " . round(($eligibleStructureForPayment[$i]->fssm_amount - $paidAmount), 2) . "/-", 'fssm_due_amount_hidden' => round(($eligibleStructureForPayment[$i]->fssm_amount - $paidAmount), 2), 'paying_for_year_sem' => $semester, 'course_time_type' => $timeMgmtFlag, 'counselling_fee_info' => $cousellingFeeInfo, 'is_field_enabled' => TRUE, 'is_first_payment' => FALSE )); } } } else { $error = "Next Due Fees Has Not Been Setup. Please Ask Admin To Setup Fee Details."; break; } } } } else { $error = "No Student Data Found Against The Entered Form No./Enrl. No./Roll No."; } } else { $this->session->set_flashdata('errorMessage', "Enter Form No./Enrl. No./Roll No. Of Student."); $studentData = array(); $feeInfo = array(); } } $finalArray = array(); for ($i = 0; $i < sizeof($alreadyPaidFee); $i++) { array_push($finalArray, $alreadyPaidFee[$i]); } for ($i = 0; $i < sizeof($feeInfo); $i++) { array_push($finalArray, $feeInfo[$i]); } $viewData['error'] = $error; $viewData['studentInfo'] = $studentData; $viewData['feeInfo'] = $finalArray; $viewData['sessions'] = $this->SessionManagement->getNonDeletedActiveSessions(array('C', 'N'))->result(); $viewData['feeModes'] = $this->FeeManagement->getNonDeletedActiveFeeModes()->result(); $this->load->view('admin/fee/collectFee', $viewData); } else { redirect("admin/"); } } public function saveFeeAndGenerateReceipt() { if ($this->sessionvalidator->isLoggedIn()) { $studentInfo = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy(trim($this->input->post('tspi_id')))->result()[0]; $studentCurrentSemesterInfo = $this->StudentManagement->getStudentCurrentSectionSemesterInfoBy($studentInfo->tspi_id)->result(); $councellingFeeInfo = array(); /* Handling Councelling Fee */ if ($this->input->post('paidCouncellingFee') != NULL) { $councellingFeeAmt = $this->input->post('councellingFeeAmt'); $councellingFeeMode = $this->input->post('councellingFeeMode'); $councellingFeeRefNo = $this->input->post('councellingChDDTxnNRFN'); $councellingFeeDate = date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('councellingFeePaymentDate')))); $councellingFeeInfo = array( 'fcnm_amount' => $councellingFeeAmt, 'fcnm_mode' => $councellingFeeMode, 'fcnm_ref_no' => $councellingFeeRefNo, 'fcnm_date' => $councellingFeeDate, 'frm_id' => '', 'tspi_id' => trim($this->input->post('tspi_id')), 'fcnm_added_on' => date("Y-m-d H:i:s"), 'fcnm_added_by' => $this->session->userdata("adminData")["smember_id"], 'fcnm_updated_on' => date("Y-m-d H:i:s"), 'fcnm_updated_by' => $this->session->userdata("adminData")["smember_id"] ); } /* Handling Councelling Fee */ /* Handling Compulsory Fee Against The Selected Heads */ $collectionInfo = array(); $partPaymentInfo = array(); $fssmIds = $this->input->post("selectedFssmIds"); if (is_array($fssmIds) || is_object($fssmIds)) { foreach ($fssmIds as $fssmId) { $valueOfI = $this->input->post("fssm" . $fssmId); array_push($collectionInfo, array( 'fcm_txn_id_ref_dd_ch_no' => trim($this->input->post('chDDTxnNRFN')), 'fcm_txn_id_ref_dd_ch_date' => date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))), 'fcm_bank_name' => addslashes(trim($this->input->post('bankName'))), 'fcm_semester' => $this->input->post("payingForSemOrYear[$fssmId]"), 'fcm_amount' => $this->input->post("submittedAmt[$valueOfI]"), 'session_id' => $this->input->post("sessions[$fssmId]"), 'fcm_entry_on' => date("Y-m-d H:i:s"), 'tspi_id' => trim($this->input->post('tspi_id')), 'fssm_id' => $fssmId, 'fmm_id' => trim($this->input->post('feeMode')), 'frm_id' => '' )); array_push($partPaymentInfo, array( 'fssm_id' => $fssmId, 'is_part_payment' => ($this->input->post("submittedAmt[$valueOfI]") < $this->input->post("fssm_amounts[$fssmId]")) ? true : false )); } } /* Handling Compulsory Fee Against The Selected Heads */ /* Handling Fee Receipt Info */ $newFeeReceiptInfo = array( 'frm_receipt_date' => date("Y-m-d"), 'frm_receipt_no' => '', 'frm_total_amount' => trim($this->input->post("totalFeeCollected")), 'frm_remarks' => addslashes(trim($this->input->post('remarks'))), 'frm_title' => addslashes(trim($this->input->post('receiptTitle'))), 'frm_generated_on' => date("Y-m-d H:i:s"), 'frm_generated_by' => $this->session->userdata("adminData")["smember_id"], 'frm_updated_on' => date("Y-m-d H:i:s"), 'frm_updated_by' => $this->session->userdata("adminData")["smember_id"] ); $newStudentSectionSemesterAllotmentInfo = array(); $studentStatusUpdate = array(); $isFirstPayment = trim($this->input->post('isFirstPayment')); if ($isFirstPayment) { $newStudentSectionSemesterAllotmentInfo = array( 'tsssi_section' => 'NA', 'tsssi_semester' => ($studentInfo->tcsm_course_type == "Regular") ? "1" : "3", 'tsssi_updated_on' => date("Y-m-d H:i:s"), 'tsssi_updated_by' => $this->session->userdata("adminData")["smember_id"], 'tspi_id' => trim($this->input->post('tspi_id')) ); $studentStatusUpdate = array( 'tspi_id' => trim($this->input->post('tspi_id')), 'tspi_status' => 'CE', 'tspi_updated_on' => date("Y-m-d H:i:s"), 'tspi_updated_by' => $this->session->userdata("adminData")["smember_id"] ); } $this->db->trans_start(); $frm_id = $this->FeeManagement->createNewReceipt($newFeeReceiptInfo); $receiptNumber = date('Ymd') . "/" . $frm_id; $updateReceiptInfo = array( 'frm_id' => $frm_id, 'frm_receipt_no' => $receiptNumber, ); $this->FeeManagement->updateFeeReceiptInfo($updateReceiptInfo); for ($i = 0; $i < sizeof($collectionInfo); $i++) { $collectionInfo[$i]['frm_id'] = $frm_id; } $this->FeeManagement->createFeeCollectionInfoMulti($collectionInfo); if (sizeof($councellingFeeInfo)) { $councellingFeeInfo['frm_id'] = $frm_id; $this->FeeManagement->createNewCouncellingFee($councellingFeeInfo); } if (!sizeof($studentCurrentSemesterInfo)) { if (sizeof($newStudentSectionSemesterAllotmentInfo)) { $this->StudentManagement->createNewStudentSectionSemesterInfo($newStudentSectionSemesterAllotmentInfo); } if (sizeof($studentStatusUpdate)) { $this->StudentManagement->updateStudentPersonalInfo($studentStatusUpdate); } } $this->db->trans_complete(); /* Handling Fee Receipt Info & Making Entries */ /* Setting Data For Fee Receipt */ $chqDDTxnNEFTRefNo = trim($this->input->post('chDDTxnNRFN')); $chqDDTxnNEFTDate = date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))); $totalPaid = trim($this->input->post("totalFeeCollected")); $paymentModeInfo = $this->FeeManagement->getFeeModeInfoBy(trim($this->input->post('feeMode')))->result()[0]; $councellingFeePaymentModeInfo = ""; $councellingFeeDate = ""; $councellingFeeAmt = ""; $coucellingRefNo = ""; if (sizeof($councellingFeeInfo)) { $councellingFeePaymentModeInfo = $this->FeeManagement->getFeeModeInfoBy(trim($this->input->post('councellingFeeMode')))->result()[0]; $councellingFeeDate = date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('councellingFeePaymentDate')))); $councellingFeeAmt = trim($this->input->post('councellingFeeAmt')); $coucellingRefNo = trim($this->input->post('councellingChDDTxnNRFN')); } $collectionInfoDetails = array(); for ($i = 0; $i < sizeof($collectionInfo); $i++) { $feeStructureInfo = $this->FeeManagement->getFeeStructureDetailsOfStudentById($collectionInfo[$i]['fssm_id'])->result()[0]; array_push($collectionInfoDetails, array( 'fee_head' => stripslashes($feeStructureInfo->fhm_short_name), 'amount_paid' => "INR(<i class='fa fa-inr'></i>) " . $collectionInfo[$i]['fcm_amount'] . "/-", 'sem_or_year' => $collectionInfo[$i]['fcm_semester'], 'is_part_payment' => ($partPaymentInfo[$i]['is_part_payment']) ? "(Partial Payment)" : "" )); } $receiptData = array( 'receipt_title' => addslashes(trim($this->input->post('receiptTitle'))), 'receipt_number' => $receiptNumber, 'receipt_date' => date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('feeReceiptDate')))), 'student_details' => $studentInfo, 'fee_mode' => stripslashes($paymentModeInfo->fmm_short_name), 'chqDDTxnNEFTRefNo' => $chqDDTxnNEFTRefNo, 'chqDDTxnNEFTDate' => (!strcasecmp(stripslashes($paymentModeInfo->fmm_short_name), "cash")) ? "NA" : $chqDDTxnNEFTDate, 'total_paid' => $totalPaid, 'total_paid_in_words' => $this->denominator->convertToWords($totalPaid), 'councelling_fee' => $councellingFeeInfo, 'councelling_amount' => $councellingFeeAmt, 'councelling_fee_mode' => (is_object($councellingFeePaymentModeInfo)) ? stripslashes($councellingFeePaymentModeInfo->fmm_short_name) : "", 'councelling_fee_ref_no' => $coucellingRefNo, 'councelling_fee_date' => $councellingFeeDate, 'collection_info' => $collectionInfoDetails, 'is_old_fee' => FALSE, 'is_cancelled' => FALSE ); $this->session->set_flashdata('successMessage', 'Fee Collection Details Saved Successfully.'); $this->load->view("admin/fee/receipt", $receiptData); } else { redirect("admin/"); } } public function showReceipt($frm_id) { if ($this->sessionvalidator->isLoggedIn()) { $fee_collection_details = array(); $receiptInfo = $this->FeeManagement->getFeeReceiptInfoById($frm_id)->result()[0]; $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsByReceipt($frm_id)->result(); $studentInfo = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($paidFeeInfo[0]->tspi_id)->result()[0]; $councellingFeeInfo = $this->FeeManagement->getPaidCouncellingFeeDetailsByStudent($studentInfo->tspi_id)->result(); $chqDDTxnNEFTRefNo = stripslashes($paidFeeInfo[0]->fcm_txn_id_ref_dd_ch_no); $chqDDTxnNEFTDate = date("d-m-Y", strtotime($paidFeeInfo[0]->fcm_txn_id_ref_dd_ch_date)); $totalPaid = $receiptInfo->frm_total_amount; $paymentMode = stripslashes($paidFeeInfo[0]->fmm_short_name); for ($rFee = 0; $rFee < sizeof($paidFeeInfo); $rFee++) { $feeStructureInfo = $this->FeeManagement->getFeeStructureDetailsOfStudentById($paidFeeInfo[$rFee]->fssm_id)->result()[0]; array_push($fee_collection_details, array( 'fee_head' => $feeStructureInfo->fhm_name, 'amount_paid' => "INR(<i class='fa fa-inr'></i>) " . $paidFeeInfo[$rFee]->fcm_amount . "/-", 'sem_or_year' => $paidFeeInfo[$rFee]->fcm_semester, 'is_part_payment' => ($paidFeeInfo[$rFee]->fcm_amount < $paidFeeInfo[$rFee]->fssm_amount) ? "(Partial Payment)" : "" )); } $receiptData = array( 'receipt_title' => stripslashes($receiptInfo->frm_title), 'receipt_number' => stripslashes($receiptInfo->frm_receipt_no), 'receipt_date' => date("d-m-Y", strtotime($receiptInfo->frm_receipt_date)), 'fee_details' => $fee_collection_details, 'student_details' => $studentInfo, 'fee_mode' => $paymentMode, 'chqDDTxnNEFTRefNo' => $chqDDTxnNEFTRefNo, 'chqDDTxnNEFTDate' => (!strcasecmp($paymentMode, "cash")) ? "NA" : $chqDDTxnNEFTDate, 'total_paid' => $totalPaid, 'total_paid_in_words' => $this->denominator->convertToWords($totalPaid), 'councelling_fee' => $councellingFeeInfo, 'councelling_amount' => (sizeof($councellingFeeInfo)) ? $councellingFeeInfo[0]->fcnm_amount : "-", 'councelling_fee_mode' => (sizeof($councellingFeeInfo)) ? stripslashes($councellingFeeInfo[0]->fmm_short_name) : "-", 'councelling_fee_ref_no' => (sizeof($councellingFeeInfo)) ? stripslashes($councellingFeeInfo[0]->fcnm_ref_no) : "-", 'councelling_fee_date' => (sizeof($councellingFeeInfo)) ? date("d-m-Y", strtotime($councellingFeeInfo[0]->fcnm_date)) : "-", 'collection_info' => $fee_collection_details, 'is_old_fee' => 'S', 'is_cancelled' => ($receiptInfo->frm_status == "C") ? TRUE : FALSE ); $this->load->view("admin/fee/receipt", $receiptData); } else { redirect("admin/"); } } public function receiptManagement() { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $selectedPattern = ""; $selectedSession = ""; $selectedEntryType = ""; $filteredRecords = array(); if (isset($_POST['filterSubmitBtn'])) { $filterPattern = $this->input->post('filterPattern'); $selectedPattern = $filterPattern; if ($filterPattern != "") { if ($filterPattern == 'FNW') { $reqFormEnrllRollNumber = trim($this->input->post('stuFormEnrlRoll')); if ($reqFormEnrllRollNumber == "") { $this->session->set_flashdata('errorMessage', "Enter Form Number/Enrl. No./Roll Number To Search."); } else { $this->session->set_flashdata('errorMessage', NULL); $filteredRecords = $this->FeeManagement->getFeeReceiptInfoBy("", $reqFormEnrllRollNumber, "", "", "")->result(); } } else if ($filterPattern == 'RNW') { $reqReceiptNumber = trim($this->input->post('receiptNo')); if ($reqReceiptNumber == "") { $this->session->set_flashdata('errorMessage', "Enter Receipt Number To Search."); } else { $this->session->set_flashdata('errorMessage', NULL); $filteredRecords = $this->FeeManagement->getFeeReceiptInfoBy($reqReceiptNumber, "", "", "", "")->result(); } } else { $reqCourse = $this->input->post('stuCourse'); if ($reqCourse == "") { $this->session->set_flashdata('errorMessage', "Please Select Course To Search Receipt."); } else { $selectedSession = $this->input->post('stuSession'); $selectedEntryType = $this->input->post('stuEntryType'); $filteredRecords = $this->FeeManagement->getFeeReceiptInfoBy("", "", $reqCourse, trim($selectedSession), trim($selectedEntryType))->result(); } } } else { $filteredRecords = array(); } } $viewData['branches'] = $this->BranchManagement->getAllNonDeletedActiveBrances()->result(); $viewData['courses'] = $this->CourseManagement->getActiveAndNonDeletedCourses()->result(); $viewData['selectedPattern'] = $selectedPattern; $viewData['selectedSession'] = $selectedSession; $viewData['selectedEntryType'] = $selectedEntryType; $viewData['filteredRecords'] = $filteredRecords; $this->load->view("admin/fee/viewReceipts", $viewData); } else { redirect("admin/"); } } public function cfReimbursement() { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $filteredRecords = array(); $message = ""; if (isset($_POST['filterSubmitBtn'])) { $selectedCollectedForSession = trim($this->input->post("collectionForSession")); $selectedCourse = trim($this->input->post("stuCourse")); $filteredRecords = $this->FeeManagement->getReimbursementCounsellingFeeReport($selectedCollectedForSession, $selectedCourse, 'A', '')->result(); $message = (sizeof($filteredRecords)) ? "" : "There Is No Pending Fee To Update For Reimbursement."; } $viewData['collectionSessions'] = $this->SessionManagement->getNonDeletedActiveSessions(array('C', 'N'))->result(); $viewData['courses'] = $this->CourseManagement->getActiveAndNonDeletedCourses()->result(); $viewData['feeModes'] = $this->FeeManagement->getNonDeletedActiveFeeModes()->result(); $viewData['filteredRecords'] = $filteredRecords; $viewData['error'] = $message; $this->load->view("admin/fee/updateReimbursment", $viewData); } else { redirect("admin/"); } } public function saveReimbursementReceipt() { if ($this->sessionvalidator->isLoggedIn()) { $selectedReceipts = $this->input->post('selectedReceipts'); $toUpdateReimbursement = array(); for ($i = 0; $i < sizeof($selectedReceipts); $i++) { array_push($toUpdateReimbursement, array( 'fcnm_id' => $selectedReceipts[$i], 'fcnm_rem_date' => (trim($this->input->post("rmbDate[$selectedReceipts[$i]]")) == "") ? NULL : date("Y-m-d", strtotime(str_replace('/', '-', trim($this->input->post("rmbDate[$selectedReceipts[$i]]"))))), 'fcnm_rem_ref_no' => (trim($this->input->post("rmbDate[$selectedReceipts[$i]]")) == "") ? NULL : addslashes(trim($this->input->post("rmbRefNo[$selectedReceipts[$i]]"))), 'fcnm_rem_mode' => (trim($this->input->post("rmbDate[$selectedReceipts[$i]]")) == "") ? NULL : trim($this->input->post("rmbMode[$selectedReceipts[$i]]")), 'fcnm_updated_on' => date("Y-m-d H:i:s"), 'fcnm_updated_by' => $this->session->userdata("adminData")["smember_id"] )); } if (sizeof($toUpdateReimbursement)) { $this->FeeManagement->updateCounsellingFeeInfoMulti($toUpdateReimbursement); } $this->db->trans_complete(); $this->session->set_flashdata('successMessage', 'Fee Reimbursement Data Updated Successfully.'); redirect("admin/Fee/cfReimbursement"); } else { redirect("admin/"); } } public function cancelReceipt() { if ($this->sessionvalidator->isLoggedIn()) { $frm_id = trim($this->input->post('modReceiptId')); $tspi_id = trim($this->input->post('modStudentId')); $cancel_reason_flag = trim($this->input->post('modCancelReasonFlag')); $cancel_reason = addslashes(trim($this->input->post('modReceiptCancelReason'))); $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsByReceipt($frm_id)->result()[0]; $paidForSemesterOrYearOfReceipt = $paidFeeInfo->fcm_semester; $student_info = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($tspi_id)->result()[0]; $studentCurrentSemesterInfo = $this->StudentManagement->getStudentCurrentSectionSemesterInfoBy($tspi_id)->result(); $studentCurrentSemesterOrYear = (sizeof($studentCurrentSemesterInfo)) ? $studentCurrentSemesterInfo[0]->tsssi_semester : $student_info->tcsm_sem_start_from; if ($studentCurrentSemesterOrYear <= $paidForSemesterOrYearOfReceipt) { $receiptUpdateData = array( 'frm_id' => $frm_id, 'frm_status' => 'C', 'frm_cancel_flag' => $cancel_reason_flag, 'frm_updated_on' => date("Y-m-d H:i:s"), 'frm_updated_by' => $this->session->userdata("adminData")["smember_id"], 'frm_cancel_reason' => $cancel_reason ); if ($this->FeeManagement->updateFeeReceiptInfo($receiptUpdateData)) { $counsellingFeeInfo = $this->FeeManagement->getPaidCouncellingFeeDetailsBy($frm_id)->result(); if (sizeof($counsellingFeeInfo)) { $cousellingFeeUpdateData = array( 'fcnm_id' => $counsellingFeeInfo[0]->fcnm_id, 'fcnm_updated_on' => date("Y-m-d H:i:s"), 'fcnm_updated_by' => $this->session->userdata("adminData")["smember_id"], 'fcnm_status' => 'C' ); $this->FeeManagement->updateCounsellingFeeInfo($cousellingFeeUpdateData); } $responseData = array( 'csrfName' => $this->security->get_csrf_token_name(), 'csrfHash' => $this->security->get_csrf_hash(), 'if_cancelled' => 1, 'message' => "Fee Receipt Cancelled Successfully." ); } else { $responseData = array( 'csrfName' => $this->security->get_csrf_token_name(), 'csrfHash' => $this->security->get_csrf_hash(), 'if_cancelled' => 0, 'message' => "An Error Occured While Cancelling This Receipt. Try Later." ); } } else { $responseData = array( 'csrfName' => $this->security->get_csrf_token_name(), 'csrfHash' => $this->security->get_csrf_hash(), 'if_cancelled' => -1, 'message' => "This Receipt Can No Be Cancelled As It Belongs To Previous Year/Semester. Only Current Or Beyond Year/Semester Receipt Can Be Cancelled." ); } echo json_encode($responseData); } else { redirect("admin/"); } } public function getReceiptFullInfo() { $frm_id = $this->input->post('frm_id'); $receiptInfo = $this->FeeManagement->getFeeReceiptInfoById($frm_id)->result()[0]; $paidFeeInfo = $this->FeeManagement->getPaidFeeDetailsByReceipt($frm_id)->result(); $counsellingFeeInfo = $this->FeeManagement->getPaidCouncellingFeeDetailsBy($frm_id)->result(); $feeDetails = array(); $feeMode = ""; $feeChqDDNEFTRefNo = ""; $feeChqDDNEFTDate = ""; $tspiId = ""; $cousellingFeeSubmitted = "No"; $counsellingFeeAmt = "<i class='fa fa-inr'></i> 0.0/-"; $counsellingFeeMode = "-"; $counsellingFeeRefNo = "-"; $counsellingFeeDate = "-"; for ($i = 0; $i < sizeof($paidFeeInfo); $i++) { array_push($feeDetails, array( 'fhm_name' => stripslashes($paidFeeInfo[$i]->fhm_name), 'fhm_type' => ($paidFeeInfo[$i]->fhm_type == "O") ? "One-Time" : (($paidFeeInfo[$i]->fhm_type == "R") ? "Recurring" : "Fine"), 'fcm_amount' => "<i class='fa fa-inr'></i> " . $paidFeeInfo[$i]->fcm_amount . "/- INR", 'fcm_sem_year' => $paidFeeInfo[$i]->fcm_semester, 'fcm_for_session' => stripslashes($paidFeeInfo[$i]->session_name) )); $feeChqDDNEFTRefNo = stripslashes($paidFeeInfo[$i]->fcm_txn_id_ref_dd_ch_no); $feeChqDDNEFTDate = ($paidFeeInfo[$i]->fcm_txn_id_ref_dd_ch_date == "1970-01-01") ? "Invalid Date" : date('d-m-Y', strtotime($paidFeeInfo[$i]->fcm_txn_id_ref_dd_ch_date)); $feeMode = stripslashes($paidFeeInfo[$i]->fmm_short_name); $tspiId = $paidFeeInfo[$i]->tspi_id; } if (sizeof($counsellingFeeInfo)) { $cousellingFeeSubmitted = "Yes"; $counsellingFeeAmt = "<i class='fa fa-inr'></i> " . $counsellingFeeInfo[0]->fcnm_amount . "/-"; $counsellingFeeMode = stripslashes($counsellingFeeInfo[0]->fmm_short_name); $counsellingFeeRefNo = stripslashes($counsellingFeeInfo[0]->fcnm_ref_no); $counsellingFeeDate = date('d-m-Y', strtotime($counsellingFeeInfo[0]->fcnm_date)); } $student_info = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($tspiId)->result()[0]; $gender = ""; if ($student_info->tspi_gender == "M") { $gender = "<i class='fa fa-male'></i>|Male"; } else if ($student_info->tspi_gender == "F") { $gender = "<i class='fa fa-female'></i>|Female"; } else { $gender = "<i class='fa fa-transgender'></i>|Transgender"; } $responseData = array( 'csrfName' => $this->security->get_csrf_token_name(), 'csrfHash' => $this->security->get_csrf_hash(), 'frm_id' => $receiptInfo->frm_id, 'frm_receipt_no' => stripslashes($receiptInfo->frm_receipt_no), 'frm_status' => ($receiptInfo->frm_status == "A") ? "No" : "Yes", 'frm_receipt_date' => ($receiptInfo->frm_receipt_date == "1970-01-01") ? "Invalid Date" : date('d-m-Y', strtotime($receiptInfo->frm_receipt_date)), 'frm_total_amount' => "<i class='fa fa-inr'></i> " . $receiptInfo->frm_total_amount . "/- INR", 'frm_mode' => $feeMode, 'frm_chqDDNEFTRefNo' => $feeChqDDNEFTRefNo, 'frm_chqDDNEFTDate' => $feeChqDDNEFTDate, 'frm_fee_details' => $feeDetails, 'frm_remarks' => stripslashes($receiptInfo->frm_remarks), 'frm_generated_by' => stripslashes($receiptInfo->addedByAdmin) . " On " . date("d-m-Y h:i:s A", strtotime($receiptInfo->frm_generated_on)), 'frm_cancelled_by' => ($receiptInfo->frm_status == "C") ? stripslashes($receiptInfo->updatedByAdmin) . " On " . date("d-m-Y h:i:s A", strtotime($receiptInfo->frm_updated_on)) : "-", 'frm_counselling_fee' => $cousellingFeeSubmitted, 'frm_counselling_fee_amt' => $counsellingFeeAmt, 'frm_counselling_fee_mode' => $counsellingFeeMode, 'frm_counselling_fee_ref_no' => $counsellingFeeRefNo, 'frm_counselling_fee_date' => $counsellingFeeDate, 'stu_form_no' => stripslashes($student_info->tspi_form_no), 'stu_enrollment_no' => ($student_info->tspi_form_no == $student_info->tspi_enrollment_no) ? "-" : stripslashes($student_info->tspi_enrollment_no), 'stu_roll_no' => ($student_info->tspi_form_no == $student_info->tspi_rollNumber) ? "-" : stripslashes($student_info->tspi_rollNumber), 'stu_name' => stripslashes($student_info->tspi_name), 'stu_course' => stripslashes($student_info->course_name), 'stu_entry_type' => stripslashes($student_info->tcsm_course_type), 'stu_session' => stripslashes($student_info->session_name), 'stu_batch' => explode('-', $student_info->session_name)[0] . "-" . $student_info->session_end_year, 'stu_gender' => $gender, 'stu_dob' => date('d-m-Y', strtotime($student_info->tspi_dob)), 'stu_mobile' => $student_info->tspi_mobile ); echo json_encode($responseData); } /* Request Hanlder For Hostel Fee Collection */ public function collectOptionalFee() { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $error = ""; $studentData = array(); $optionalFeeInfo = array(); $viewData['feeDetail'] = array(); $viewData['paidFee'] = array(); $amount = 0; if (isset($_POST['fetchStudentInfo'])) { $formEnrlRollNo = addslashes(trim($this->input->post('formEnrlRollNo'))); if ($formEnrlRollNo != "") { $this->session->set_flashdata('errorMessage', NULL); $studentData = $this->StudentManagement->getStudentInfoByFormEnrollmentOrRollNo($formEnrlRollNo)->result(); $viewData['paidFee'] = $this->FeeManagement->getAllPaidFeesByFormNumber($formEnrlRollNo)->result(); $viewData['feeDetail'] = $this->FeeManagement->getPaidAndHeadFees($formEnrlRollNo)->result(); for ($i = 0; $i < sizeof($viewData['paidFee']); $i++) { $amount = $amount + $viewData['paidFee'][$i]->fcom_amount; } $viewData['paidFee'] = $amount; if (sizeof($studentData)) { $student_info = $studentData[0]; $studentFatherName = $this->StudentManagement->getStudentFatherInfoBy($student_info->tspi_id)->result()[0]->tfbi_name; $studentCurrentSemesterInfo = $this->StudentManagement->getStudentCurrentSectionSemesterInfoBy($student_info->tspi_id)->result(); $gender = ""; $studentCurrentSemesterOrYear = ""; $semesterOrYearToShow = ""; $entryType = stripslashes($student_info->tcsm_course_type); if ($student_info->tspi_gender == "M") { $gender = "<i class='fa fa-male'></i>|Male"; } else if ($student_info->tspi_gender == "F") { $gender = "<i class='fa fa-female'></i>|Female"; } else { $gender = "<i class='fa fa-transgender'></i>|Transgender"; } if (sizeof($studentCurrentSemesterInfo)) { $studentCurrentSemesterOrYear = $studentCurrentSemesterInfo[0]->tsssi_semester; $semesterOrYearToShow = $studentCurrentSemesterOrYear; } else { $studentCurrentSemesterOrYear = $student_info->tcsm_sem_start_from; $semesterOrYearToShow = "New Admission"; } $studentData = array( 'stu_id' => $student_info->tspi_id, 'stu_name' => stripslashes($student_info->tspi_name), 'stu_father_name' => stripslashes($studentFatherName), 'stu_gender' => $gender, 'stu_form_no' => stripslashes($student_info->tspi_form_no), 'stu_roll_no' => ($student_info->tspi_form_no == $student_info->tspi_rollNumber) ? "-" : stripslashes($student_info->tspi_rollNumber), 'stu_enrollment_no' => ($student_info->tspi_form_no == $student_info->tspi_enrollment_no) ? "-" : stripslashes($student_info->tspi_enrollment_no), 'stu_dob' => date('d-m-Y', strtotime($student_info->tspi_dob)), 'stu_course' => stripslashes($student_info->course_name), 'stu_entry_type' => $entryType, 'stu_session' => stripslashes($student_info->session_name), 'stu_batch' => explode('-', $student_info->session_name)[0] . "-" . $student_info->session_end_year, 'stu_entry_type' => stripslashes($student_info->tcsm_course_type), 'stu_photograph' => base_url("assets/admin/uploads/studentData/") . $student_info->studentPhoto, 'stu_sign' => base_url("assets/admin/uploads/studentData/") . $student_info->studentSign, 'stu_current_semester' => $semesterOrYearToShow ); } else { $error = "No Student Data Found Against The Entered Form No./Enrl. No./Roll No."; } $optionalFeeInfo = $this->FeeManagement->getNonDeletedOptionalFeeHeadsBy('H')->result(); } else { $this->session->set_flashdata('errorMessage', "Enter Form No./Enrl. No./Roll No. Of Student."); $studentData = array(); $optionalFeeInfo = array(); } } $viewData['error'] = $error; $viewData['studentInfo'] = $studentData; $viewData['optionalFeeInfo'] = (sizeof($optionalFeeInfo)) ? $optionalFeeInfo : array(); $viewData['sessions'] = $this->SessionManagement->getNonDeletedActiveSessions(array('C', 'N'))->result(); $viewData['feeModes'] = $this->FeeManagement->getNonDeletedActiveFeeModes()->result(); $this->load->view('admin/hostel/collectOptionalFee', $viewData); } else { redirect("admin/"); } } public function saveOptionalFeeAndGenerateReceipt() { if ($this->sessionvalidator->isLoggedIn()) { $feeAmount = $this->input->post("amountNeedToPay"); $studentStatusUpdate = array(); $newFeeReceiptInfo = array( 'from_receipt_date' => date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('feeReceiptDate')))), 'from_receipt_no' => '', 'session_id' => trim($this->input->post("session")), 'from_total_amount' => trim($feeAmount), 'from_generated_on' => date("Y-m-d H:i:s"), 'from_generated_by' => $this->session->userdata("adminData")["smember_id"], 'from_updated_on' => date("Y-m-d H:i:s"), 'from_updated_by' => $this->session->userdata("adminData")["smember_id"] ); $this->db->trans_start(); $from_id = $this->FeeManagement->createNewOptionalReceipt($newFeeReceiptInfo); $receiptNumber = "H" . date("Ymd") . "/" . $from_id; $updateReceiptInfo = array( 'from_id' => $from_id, 'from_receipt_no' => $receiptNumber, ); $this->FeeManagement->updateOptionalFeeReceiptInfo($updateReceiptInfo); $submittedFee = array( 'fcom_txn_id_ref_dd_ch_no' => addslashes(trim($this->input->post('chDDTxnNRFN'))), 'fcom_txn_id_ref_dd_ch_date' => date("Y-m-d", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))), 'fcom_semester' => trim($this->input->post('payingForSemOrYear')), 'fcom_amount' => trim($feeAmount), 'fcom_entry_on' => date("Y-m-d H:i:s"), 'tspi_id' => trim($this->input->post('tspi_id')), 'fmm_id' => trim($this->input->post('feeMode')), 'fsom_id' => trim($this->input->post('fsom_id')), 'from_id' => $from_id ); $this->FeeManagement->createOptionalFeeCollectionInfo($submittedFee); if (sizeof($studentStatusUpdate)) { $this->StudentManagement->updateStudentPersonalInfo($studentStatusUpdate); } $this->db->trans_complete(); /* Setting Data For Fee Receipt */ $chqDDTxnNEFTRefNo = trim($this->input->post('chDDTxnNRFN')); $chqDDTxnNEFTDate = date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('chDDNEFTDate')))); //$paidForSemOrYear = trim($this->input->post('payingForSemOrYear')); $totalPaid = $feeAmount; $paymentModeInfo = $this->FeeManagement->getFeeModeInfoBy(trim($this->input->post('feeMode')))->result(); $studentInfo = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy(trim($this->input->post('tspi_id')))->result(); //$feeStructureInfo = $this->FeeManagement->getOptionalFeeStructureInfoById(trim($this->input->post('fsom_id')))->result(); $sessionData = $this->SessionManagement->getSessionInfoBy(trim($this->input->post("session")))->result(); $receiptData = array( 'receipt_number' => $receiptNumber, 'receipt_date' => date("d-m-Y", strtotime(str_replace('/', '-', $this->input->post('feeReceiptDate')))), //'fee_head' => $feeStructureInfo, 'amount_paid' => $feeAmount, 'student_details' => $studentInfo[0], 'fee_mode' => $paymentModeInfo[0], 'chqDDTxnNEFTRefNo' => $chqDDTxnNEFTRefNo, 'chqDDTxnNEFTDate' => $chqDDTxnNEFTDate, 'session' => $sessionData[0]->session_name, 'total_paid' => $totalPaid, 'is_old_fee' => false ); $this->session->set_flashdata('successMessage', 'Fee Collection Details Saved Successfully.'); $this->load->view("admin/hostel/receipt", $receiptData); } else { redirect("admin/"); } } /* Request Handler For Hostel Fee Receipt */ public function showHostelFeeReceipt($from_id) { if ($this->sessionvalidator->isLoggedIn()) { $receiptInfo = $this->FeeManagement->getHostelFeeReceiptInfoById($from_id)->result()[0]; $paidFeeInfo = $this->FeeManagement->getPaidHostelFeeDetailsByReceipt($from_id)->result(); $studentInfo = $this->StudentManagement->getStudentPersonalInfoAndPhotoSignBy($paidFeeInfo[0]->tspi_id)->result()[0]; $chqDDTxnNEFTRefNo = stripslashes($paidFeeInfo[0]->fcom_txn_id_ref_dd_ch_no); $chqDDTxnNEFTDate = date("d-m-Y", strtotime($paidFeeInfo[0]->fcom_txn_id_ref_dd_ch_date)); $totalPaid = $receiptInfo->from_total_amount; $paymentMode = $paidFeeInfo[0]; $receiptData = array( 'receipt_number' => stripslashes($receiptInfo->from_receipt_no), 'receipt_date' => date("d-m-Y", strtotime($receiptInfo->from_receipt_date)), 'student_details' => $studentInfo, 'fee_mode' => $paymentMode, 'chqDDTxnNEFTRefNo' => $chqDDTxnNEFTRefNo, 'chqDDTxnNEFTDate' => $chqDDTxnNEFTDate, 'total_paid' => $totalPaid, 'session' => $paidFeeInfo[0]->session_name, 'is_old_fee' => true ); $this->load->view("admin/hostel/receipt", $receiptData); } else { redirect("admin/"); } } public function optionalFeeReceiptManagement() { if ($this->sessionvalidator->isLoggedIn() && $this->sessionvalidator->isAccessGranted()) { $selectedPattern = ""; $selectedSession = ""; $selectedEntryType = ""; $filteredRecords = array(); if (isset($_POST['filterSubmitBtn'])) { $filterPattern = $this->input->post('filterPattern'); $selectedPattern = $filterPattern; if ($filterPattern != "") { if ($filterPattern == 'FNW') { $reqFormEnrllRollNumber = trim($this->input->post('stuFormEnrlRoll')); if ($reqFormEnrllRollNumber == "") { $this->session->set_flashdata('errorMessage', "Enter Form Number/Enrl. No./Roll Number To Search."); } else { $this->session->set_flashdata('errorMessage', NULL); $filteredRecords = $this->FeeManagement->getOptionalFeeReceiptInfoBy("", $reqFormEnrllRollNumber, "", "", "")->result(); } } else if ($filterPattern == 'RNW') { $reqReceiptNumber = trim($this->input->post('receiptNo')); if ($reqReceiptNumber == "") { $this->session->set_flashdata('errorMessage', "Enter Receipt Number To Search."); } else { $this->session->set_flashdata('errorMessage', NULL); $filteredRecords = $this->FeeManagement->getOptionalFeeReceiptInfoBy($reqReceiptNumber, "", "", "", "")->result(); } } else { $reqCourse = $this->input->post('stuCourse'); if ($reqCourse == "") { $this->session->set_flashdata('errorMessage', "Please Select Course To Search Receipt."); } else { $selectedSession = $this->input->post('stuSession'); $selectedEntryType = $this->input->post('stuEntryType'); $filteredRecords = $this->FeeManagement->getOptionalFeeReceiptInfoBy("", "", $reqCourse, trim($selectedSession), trim($selectedEntryType))->result(); } } } else { $filteredRecords = array(); } } else if (isset($_POST['cancelBtn'])) { $receipts = $this->input->post("chk"); $receiptUpdateData = array(); $from_ids = 0; foreach ($receipts as $from_id) { array_push($receiptUpdateData, array( 'from_id' => $from_id, 'from_status' => 'C', 'from_updated_on' => date("Y-m-d H:i:s"), 'from_updated_by' => $this->session->userdata("adminData")["smember_id"], 'from_cancel_reason' => trim($this->input->post("cancelReason")) )); $from_ids = $from_id; } $this->db->trans_start(); $this->FeeManagement->updateOptionalFeeReceiptInfoInBulk($receiptUpdateData); $receipt_details = $this->FeeManagement->getOptionalFeeReceiptInfo($from_ids)->result(); $allotmentDetail = $this->HostelManagement->getAllotmentDetailsBy($receipt_details[0]->tspi_id, $receipt_details[0]->session_id)->result(); if (sizeof($allotmentDetail)) { $array = array( 'sha_status' => 'C', 'sha_updated_on' => date("Y-m-d H:i:s"), 'sha_updated_by' => $this->session->userdata("adminData")["smember_id"] ); $this->HostelManagement->updateRoomAllotment($array, $allotmentDetail[0]->sha_id); } $this->session->set_flashdata("successMessage", "Fee Receipt Cancelled Suucessfully."); $this->db->trans_complete(); } $viewData['branches'] = $this->BranchManagement->getAllNonDeletedActiveBrances()->result(); $viewData['courses'] = $this->CourseManagement->getActiveAndNonDeletedCourses()->result(); $viewData['selectedPattern'] = $selectedPattern; $viewData['selectedSession'] = $selectedSession; $viewData['selectedEntryType'] = $selectedEntryType; $viewData['filteredRecords'] = $filteredRecords; $this->load->view("admin/fee/viewOptionalFeeReceipts", $viewData); } else { redirect("admin/"); } } }