JFIFXX    $.' ",#(7),01444'9=82<.342  2!!22222222222222222222222222222222222222222222222222"4 ,PG"Z_4˷kjزZ,F+_z,© zh6٨icfu#ډb_N?wQ5-~I8TK<5oIv-k_U_~bMdӜUHh?]EwQk{_}qFW7HTՑYF?_'ϔ_Ջt=||I 6έ"D/[k9Y8ds|\Ҿp6Ҵ].6znopM[mei$[soᘨ˸ nɜG-ĨUycP3.DBli;hjx7Z^NhN3u{:jx힞#M&jL P@_ P&o89@Sz6t7#Oߋ s}YfTlmrZ)'Nk۞pw\Tȯ?8`Oi{wﭹW[r Q4F׊3m&L=h3z~#\l :F,j@ ʱwQT8"kJO6֚l}R>ډK]y&p}b;N1mr$|7>e@BTM*-iHgD) Em|ؘbҗaҾt4oG*oCNrPQ@z,|?W[0:n,jWiEW$~/hp\?{(0+Y8rΟ+>S-SVN;}s?. w9˟<Mq4Wv'{)01mBVW[8/< %wT^5b)iM pgN&ݝVO~qu9 !J27$O-! :%H ـyΠM=t{!S oK8txA& j0 vF Y|y ~6@c1vOpIg4lODL Rcj_uX63?nkWyf;^*B @~a`Eu+6L.ü>}y}_O6͐:YrGXkGl^w~㒶syIu! W XN7BVO!X2wvGRfT#t/?%8^WaTGcLMI(J1~8?aT ]ASE(*E} 2#I/׍qz^t̔bYz4xt){ OH+(EA&NXTo"XC')}Jzp ~5}^+6wcQ|LpdH}(.|kc4^"Z?ȕ a<L!039C EuCFEwç ;n?*oB8bʝ'#RqfM}7]s2tcS{\icTx;\7KPʇ Z O-~c>"?PEO8@8GQgaՎ󁶠䧘_%#r>1zaebqcPѵn#L =׀t L7`VA{C:ge@w1 Xp3c3ġpM"'-@n4fGB3DJ8[JoߐgK)ƛ$ 83+ 6ʻ SkI*KZlT _`?KQKdB`s}>`*>,*@JdoF*弝O}ks]yߘc1GV<=776qPTtXԀ!9*44Tހ3XΛex46YD  BdemDa\_l,G/֌7Y](xTt^%GE4}bTڹ;Y)BQu>J/J ⮶.XԄjݳ+Ed r5_D1 o Bx΢#<W8R6@gM. drD>(otU@x=~v2 ӣdoBd3eO6㣷ݜ66YQz`S{\P~z m5{J/L1xO\ZFu>ck#&:`$ai>2ΔloF[hlEܺΠk:)` $[69kOw\|8}ބ:񶐕IA1/=2[,!.}gN#ub ~݊}34qdELc$"[qU硬g^%B zrpJru%v\h1Yne`ǥ:gpQM~^Xi `S:V29.PV?Bk AEvw%_9CQwKekPؠ\;Io d{ ߞoc1eP\ `E=@KIRYK2NPlLɀ)&eB+ь( JTx_?EZ }@ 6U뙢طzdWIn` D噥[uV"G&Ú2g}&m?ċ"Om# {ON"SXNeysQ@FnVgdX~nj]J58up~.`r\O,ư0oS _Ml4kv\JSdxSW<AeIX$Iw:Sy›R9Q[,5;@]%u@ *rolbI  +%m:͇ZVủθau,RW33 dJeTYE.Mϧ-oj3+yy^cVO9NV\nd1 !͕_)av;թMlWR1)ElP;yوÏu 3k5Pr6<⒲l!˞*u־n!l:UNW %Chx8vL'X@*)̮ˍ D-M+JUkvK+x8cY?Ԡ~3mo|u@[XeYC\Kpx8oCC&N~3-H MXsu<`~"WL$8ξ3a)|:@m\^`@ҷ)5p+6p%i)P Mngc#0AruzRL+xSS?ʮ}()#tmˇ!0}}y$6Lt;$ʳ{^6{v6ķܰgVcnn ~zx«,2u?cE+ȘH؎%Za)X>uWTzNyosFQƤ$*&LLXL)1" LeOɟ9=:tZcŽY?ӭVwv~,Yrۗ|yGaFC.+ v1fήJ]STBn5sW}y$~z'c 8  ,! pVNSNNqy8z˱A4*'2n<s^ǧ˭PJޮɏUGLJ*#i}K%,)[z21z ?Nin1?TIR#m-1lA`fT5+ܐcq՝ʐ,3f2Uեmab#ŠdQy>\)SLYw#.ʑf ,"+w~N'cO3FN<)j&,- љ֊_zSTǦw>?nU仆Ve0$CdrP m׈eXmVu L.bֹ [Դaզ*\y8Է:Ez\0KqC b̘cөQ=0YsNS.3.Oo:#v7[#߫ 5܎LEr49nCOWlG^0k%;YߝZǓ:S#|}y,/kLd TA(AI$+I3;Y*Z}|ӧOdv..#:nf>>ȶITX 8y"dR|)0=n46ⲑ+ra ~]R̲c?6(q;5% |uj~z8R=XIV=|{vGj\gcqz؋%Mߍ1y#@f^^>N#x#۹6Y~?dfPO{P4Vu1E1J *|%JN`eWuzk M6q t[ gGvWIGu_ft5j"Y:Tɐ*; e54q$C2d} _SL#mYpO.C;cHi#֩%+) ӍƲVSYźg |tj38r|V1#;.SQA[S#`n+$$I P\[@s(EDzP])8G#0B[ىXIIq<9~[Z멜Z⊔IWU&A>P~#dp]9 "cP Md?٥Ifتuk/F9c*9Ǎ:ØFzn*@|Iށ9N3{'['ͬҲ4#}!V Fu,,mTIkv C7vB6kT91*l '~ƞFlU'M ][ΩũJ_{iIn$L jOdxkza۪#EClx˘oVɞljr)/,߬hL#^Lф,íMƁe̩NBLiLq}(q6IçJ$WE$:=#(KBzђ xlx?>Պ+>W,Ly!_DŌlQ![ SJ1ƐY}b,+Loxɓ)=yoh@꥟/Iѭ=Py9 ۍYӘe+pJnϱ?V\SO%(t =?MR[Șd/ nlB7j !;ӥ/[-A>dNsLj ,ɪv=1c.SQO3UƀܽE̻9GϷD7(}Ävӌ\y_0[w <΍>a_[0+LF.޺f>oNTq;y\bՃyjH<|q-eɏ_?_9+PHp$[uxK wMwNی'$Y2=qKBP~Yul:[<F12O5=d]Ysw:ϮEj,_QXz`H1,#II dwrP˂@ZJVy$\y{}^~[:NߌUOdؾe${p>G3cĖlʌ ת[`ϱ-WdgIig2 }s ؤ(%#sS@~3XnRG~\jc3vӍLM[JBTs3}jNʖW;7ç?=XF=-=qߚ#='c7ڑWI(O+=:uxqe2zi+kuGR0&eniT^J~\jyp'dtGsO39* b#Ɋ p[BwsT>d4ۧsnvnU_~,vƜJ1s QIz)(lv8MU=;56Gs#KMP=LvyGd}VwWBF'à ?MHUg2 !p7Qjڴ=ju JnA suMeƆҔ!)'8Ϣٔޝ(Vpצ֖d=ICJǠ{qkԭ߸i@Ku|p=..*+xz[Aqġ#s2aƊRR)*HRsi~a &fMP-KL@ZXy'x{}Zm+:)) IJ-iu ܒH'L(7yGӜq j 6ߌg1go,kرtY?W,pefOQS!K۟cҒA|սj>=⬒˧L[ ߿2JaB~Ru:Q] 0H~]7ƼI(}cq 'ήETq?fabӥvr )o-Q_'ᴎoK;Vo%~OK *bf:-ťIR`B5!RB@ï u ̯e\_U_ gES3QTaxU<~c?*#]MW,[8Oax]1bC|踤Plw5V%){t<d50iXSUm:Z┵i"1^B-PhJ&)O*DcWvM)}Pܗ-q\mmζZ-l@}aE6F@&Sg@ݚM ȹ 4#p\HdYDoH"\..RBHz_/5˘6KhJRPmƶim3,#ccoqa)*PtRmk7xDE\Y閣_X<~)c[[BP6YqS0%_;Àv~| VS؇ 'O0F0\U-d@7SJ*z3nyPOm~P3|Yʉr#CSN@ ƮRN)r"C:: #qbY. 6[2K2uǦHYRQMV G$Q+.>nNHq^ qmMVD+-#*U̒ p욳u:IBmPV@Or[b= 1UE_NmyKbNOU}the`|6֮P>\2PVIDiPO;9rmAHGWS]J*_G+kP2KaZH'KxWMZ%OYDRc+o?qGhmdSoh\D|:WUAQc yTq~^H/#pCZTI1ӏT4"ČZ}`w#*,ʹ 0i課Om*da^gJ݅{le9uF#Tֲ̲ٞC"qߍ ոޑo#XZTp@ o8(jdxw],f`~|,s^f1t|m򸄭/ctr5s79Q4H1꠲BB@l9@C+wpxu£Yc9?`@#omHs2)=2.ljg9$YS%*LRY7Z,*=䷘$armoϰUW.|rufIGwtZwo~5 YյhO+=8fF)W7L9lM̘·Y֘YLf큹pRF99.A "wz=E\Z'a 2Ǚ#;'}G*l^"q+2FQ hjkŦ${ޮ-T٭cf|3#~RJt$b(R(rdx >U b&9,>%E\ Άe$'q't*אެb-|dSBOO$R+H)܎K1m`;J2Y~9Og8=vqD`K[F)k[1m޼cn]skz$@)!I x՝"v9=ZA=`Ɠi :E)`7vI}dYI_ o:obo 3Q&D&2= Ά;>hy.*ⅥSӬ+q&j|UƧ}J0WW< ۋS)jQRjƯrN)Gű4Ѷ(S)Ǣ8iW52No˓ ۍ%5brOnL;n\G=^UdI8$&h'+(cȁ߫klS^cƗjԌEꭔgFȒ@}O*;evWVYJ\]X'5ղkFb 6Ro՜mi Ni>J?lPmU}>_Z&KKqrIDՉ~q3fL:Se>E-G{L6pe,8QIhaXaUA'ʂs+טIjP-y8ۈZ?J$WP Rs]|l(ԓsƊio(S0Y 8T97.WiLc~dxcE|2!XKƘਫ਼$((6~|d9u+qd^389Y6L.I?iIq9)O/뚅OXXVZF[یgQLK1RҖr@v#XlFНyS87kF!AsM^rkpjPDyS$Nqnxҍ!Uf!ehi2m`YI9r6 TFC}/y^Η5d'9A-J>{_l+`A['յϛ#w:݅%X}&PStQ"-\縵/$ƗhXb*yBS;Wջ_mcvt?2}1;qSdd~u:2k52R~z+|HE!)Ǟl7`0<,2*Hl-x^'_TVgZA'j ^2ΪN7t?w x1fIzC-ȖK^q;-WDvT78Z hK(P:Q- 8nZ܃e貾<1YT<,"6{/ ?͟|1:#gW>$dJdB=jf[%rE^il:BxSּ1հ,=*7 fcG#q eh?27,!7x6nLC4x},GeǝtC.vS F43zz\;QYC,6~;RYS/6|25vTimlv& nRh^ejRLGf? ۉҬܦƩ|Ȱ>3!viʯ>vオX3e_1zKȗ\qHS,EW[㺨uch⍸O}a>q6n6N6qN ! 1AQaq0@"2BRb#Pr3C`Scst$4D%Td ?Na3mCwxAmqmm$4n淿t'C"wzU=D\R+wp+YT&պ@ƃ3ޯ?AﶂaŘ@-Q=9Dռѻ@MVP܅G5fY6# ?0UQ,IX(6ڵ[DIMNލc&υj\XR|,4 jThAe^db#$]wOӪ1y%LYm뭛CUƃߜ}Cy1XνmF8jI]HۺиE@Ii;r8ӭVFՇ| &?3|xBMuSGe=Ӕ#BE5GY!z_eqр/W>|-Ci߇t1ޯќdR3ug=0 5[?#͏qcfH{ ?u=??ǯ}ZzhmΔBFTWPxs}G93 )gGR<>r h$'nchPBjJҧH -N1N?~}-q!=_2hcMlvY%UE@|vM2.Y[|y"EïKZF,ɯ?,q?vM 80jx";9vk+ ֧ ȺU?%vcVmA6Qg^MA}3nl QRNl8kkn'(M7m9وq%ޟ*h$Zk"$9: ?U8Sl,,|ɒxH(ѷGn/Q4PG%Ա8N! &7;eKM749R/%lc>x;>C:th?aKXbheᜋ^$Iհ hr7%F$EFdt5+(M6tÜUU|zW=aTsTgdqPQb'm1{|YXNb P~F^F:k6"j! Ir`1&-$Bevk:y#ywI0x=D4tUPZHڠ底taP6b>xaQ# WeFŮNjpJ* mQN*I-*ȩFg3 5Vʊɮa5FO@{NX?H]31Ri_uѕ 0 F~:60p͈SqX#a5>`o&+<2D: ڝ$nP*)N|yEjF5ټeihyZ >kbHavh-#!Po=@k̆IEN@}Ll?jO߭ʞQ|A07xwt!xfI2?Z<ץTcUj]陎Ltl }5ϓ$,Omˊ;@OjEj(ا,LXLOЦ90O .anA7j4 W_ٓzWjcBy՗+EM)dNg6y1_xp$Lv:9"zpʙ$^JԼ*ϭo=xLj6Ju82AH3$ٕ@=Vv]'qEz;I˼)=ɯx /W(Vp$ mu񶤑OqˎTr㠚xsrGCbypG1ߠw e8$⿄/M{*}W]˷.CK\ުx/$WPwr |i&}{X >$-l?-zglΆ(FhvS*b߲ڡn,|)mrH[a3ר[13o_U3TC$(=)0kgP u^=4 WYCҸ:vQרXàtkm,t*^,}D* "(I9R>``[~Q]#afi6l86:,ssN6j"A4IuQ6E,GnHzSHOuk5$I4ؤQ9@CwpBGv[]uOv0I4\yQѸ~>Z8Taqޣ;za/SI:ܫ_|>=Z8:SUIJ"IY8%b8H:QO6;7ISJҌAά3>cE+&jf$eC+z;V rʺmyeaQf&6ND.:NTvm<- uǝ\MvZYNNT-A>jr!SnO 13Ns%3D@`ܟ 1^c< aɽ̲Xë#w|ycW=9I*H8p^(4՗karOcWtO\ƍR8'KIQ?5>[}yUײ -h=% qThG2)"ו3]!kB*pFDlA,eEiHfPs5H:Փ~H0DتDIhF3c2E9H5zԑʚiX=:mxghd(v׊9iSOd@0ڽ:p5h-t&Xqӕ,ie|7A2O%PEhtjY1wЃ!  ࢽMy7\a@ţJ 4ȻF@o̒?4wx)]P~u57X 9^ܩU;Iꭆ 5 eK27({|Y׎ V\"Z1 Z}(Ǝ"1S_vE30>p; ΝD%xW?W?vo^Vidr[/&>~`9Why;R ;;ɮT?r$g1KACcKl:'3 cﳯ*"t8~l)m+U,z`(>yJ?h>]vЍG*{`;y]IT ;cNUfo¾h/$|NS1S"HVT4uhǜ]v;5͠x'C\SBplh}N ABx%ޭl/Twʽ]D=Kžr㻠l4SO?=k M: cCa#ha)ѐxcsgPiG{+xQI= zԫ+ 8"kñj=|c yCF/*9жh{ ?4o kmQNx;Y4膚aw?6>e]Qr:g,i"ԩA*M7qB?ӕFhV25r[7 Y }LR}*sg+xr2U=*'WSZDW]WǞ<叓{$9Ou4y90-1'*D`c^o?(9uݐ'PI& fJݮ:wSjfP1F:X H9dԯ˝[_54 }*;@ܨ ðynT?ןd#4rGͨH1|-#MrS3G3).᧏3vz֑r$G"`j 1tx0<ƆWh6y6,œGagAyb)hDß_mü gG;evݝnQ C-*oyaMI><]obD":GA-\%LT8c)+y76oQ#*{(F⽕y=rW\p۩cA^e6KʐcVf5$'->ՉN"F"UQ@fGb~#&M=8טJNu9D[̤so~ G9TtW^g5y$bY'سǴ=U-2 #MCt(i lj@Q 5̣i*OsxKf}\M{EV{υƇ);HIfeLȣr2>WIȂ6ik 5YOxȺ>Yf5'|H+98pjn.OyjY~iw'l;s2Y:'lgꥴ)o#'SaaKZ m}`169n"xI *+ }FP"l45'ZgE8?[X7(.Q-*ތL@̲v.5[=t\+CNܛ,gSQnH}*FG16&:t4ُ"Ạ$b |#rsaT ]ӽDP7ո0y)e$ٕvIh'QEAm*HRI=: 4牢) %_iNݧl] NtGHL ɱg<1V,J~ٹ"KQ 9HS9?@kr;we݁]I!{ @G["`J:n]{cAEVʆ#U96j#Ym\qe4hB7Cdv\MNgmAyQL4uLjj9#44tl^}LnR!t±]rh6ٍ>yҏNfU  Fm@8}/ujb9he:AyծwGpΧh5l}3p468)Udc;Us/֔YX1O2uqs`hwgr~{ RmhN؎*q 42*th>#E#HvOq}6e\,Wk#Xb>p}դ3T5†6[@Py*n|'f֧>lư΂̺SU'*qp_SM 'c6m ySʨ;MrƋmKxo,GmPAG:iw9}M(^V$ǒѽ9| aJSQarB;}ٻ֢2%Uc#gNaݕ'v[OY'3L3;,p]@S{lsX'cjwk'a.}}& dP*bK=ɍ!;3ngΊUߴmt'*{,=SzfD Ako~Gaoq_mi}#mPXhύmxǍ΂巿zfQc|kc?WY$_Lvl߶c`?ljݲˏ!V6UЂ(A4y)HpZ_x>eR$/`^'3qˏ-&Q=?CFVR DfV9{8gnh(P"6[D< E~0<@`G6Hгcc cK.5DdB`?XQ2ٿyqo&+1^ DW0ꊩG#QnL3c/x 11[yxპCWCcUĨ80me4.{muI=f0QRls9f9~fǨa"@8ȁQ#cicG$Gr/$W(WV"m7[mAmboD j۳ l^kh׽ # iXnveTka^Y4BNĕ0 !01@Q"2AaPq3BR?@4QT3,㺠W[=JKϞ2r^7vc:9 EߴwS#dIxu:Hp9E! V 2;73|F9Y*ʬFDu&y؟^EAA(ɩ^GV:ݜDy`Jr29ܾ㝉[E;FzxYGUeYC v-txIsםĘqEb+P\ :>iC';k|zرny]#ǿbQw(r|ӹs[D2v-%@;8<a[\o[ϧwI!*0krs)[J9^ʜp1) "/_>o<1AEy^C`x1'ܣnps`lfQ):lb>MejH^?kl3(z:1ŠK&?Q~{ٺhy/[V|6}KbXmn[-75q94dmc^h X5G-}دBޟ |rtMV+]c?-#ڛ^ǂ}LkrOu>-Dry D?:ޞUǜ7V?瓮"#rչģVR;n/_ ؉vݶe5db9/O009G5nWJpA*r9>1.[tsFnQ V 77R]ɫ8_0<՜IFu(v4Fk3E)N:yڮeP`1}$WSJSQNjٺ޵#lј(5=5lǏmoWv-1v,Wmn߀$x_DȬ0¤#QR[Vkzmw"9ZG7'[=Qj8R?zf\a=OU*oBA|G254 p.w7  &ξxGHp B%$gtЏ򤵍zHNuЯ-'40;_3 !01"@AQa2Pq#3BR?ʩcaen^8F<7;EA{EÖ1U/#d1an.1ě0ʾRh|RAo3m3 % 28Q yφHTo7lW>#i`qca m,B-j݋'mR1Ήt>Vps0IbIC.1Rea]H64B>o]($Bma!=?B KǾ+Ծ"nK*+[T#{EJSQs5:U\wĐf3܆&)IԆwE TlrTf6Q|Rh:[K zc֧GC%\_a84HcObiؖV7H )*ģK~Xhչ04?0 E<}3#u? |gS6ꊤ|I#Hڛ աwX97Ŀ%SLy6č|Fa 8b$sקhb9RAu7˨pČ_\*w묦F 4D~f|("mNKiS>$d7SlA/²SL|6N}S˯g]6; #. 403WebShell
403Webshell
Server IP : 43.205.77.33  /  Your IP : 216.73.216.84
Web Server : Apache
System : Linux 43-205-77-33.cprapid.com 3.10.0-1160.119.1.el7.tuxcare.els13.x86_64 #1 SMP Fri Nov 22 06:29:45 UTC 2024 x86_64
User : dbcollege ( 1086)
PHP Version : 8.0.30
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /home/dbcollege/www/cas/application/controllers/admin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/dbcollege/www/cas/application/controllers/admin/Fee.php
<?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/");
        }
    }

}

Youez - 2016 - github.com/yon3zu
LinuXploit