ModalController.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use App\Proposal;
  6. use App\User;
  7. use App\StudentProposal;
  8. use App\Country;
  9. use App\Models\ReferUser;
  10. use App\Models\Admin;
  11. use App\Models\Requirement;
  12. use App\Models\University;
  13. use App\Models\Publication;
  14. use App\Workexperience;
  15. use App\Institution;
  16. use App\Score;
  17. use Hash;
  18. use DB;
  19. use Session;
  20. use Auth;
  21. use Mail;
  22. class ModalController extends Controller{
  23. public function get(Request $req, $name){
  24. $user = Auth::user();
  25. $carbon=new \Carbon\Carbon;
  26. $data=[
  27. 'name'=>$name,
  28. 'carbon'=>$carbon
  29. ];
  30. if($name=="apply_student_proposal"){
  31. $data['teacher'] = User::find($req->id);
  32. $data['student'] = User::find($user->id);
  33. $data['proposal']= Proposal::where('student_id',$user->id)->get();
  34. }elseif($name=="view_apply_proposal"){
  35. $data['std_proposal'] =StudentProposal::find($req->id);
  36. }elseif($name=="view_student_proposal"){
  37. $data['proposal']= Proposal::where(
  38. 'student_id',$user->id
  39. )->where(
  40. 'id',$req->id
  41. )->first();
  42. }elseif($name=="add_destination"){
  43. }elseif($name=="add_wishlist"){
  44. $user =Auth::guard('teacher')->user();
  45. $data['refer'] = new ReferUser;
  46. }elseif($name=="teacher_invited"){
  47. $data['admin'] =Admin::find($req->id);
  48. }elseif($name=="add_doc_required"){
  49. $data['std_proposal']=StudentProposal::find($req->id);
  50. }elseif($name=="edit_doc_required"){
  51. $data['requirements']=Requirement::find($req->id);
  52. }elseif($name=="landing_ragister_your_interest"){
  53. $data['countries'] =Country::where('status',1)->orderBy('name','ASC')->get();
  54. $data['universities'] =University::orderBy('name','ASC')->get();
  55. }else $name='default';
  56. return view("modal_pages.{$name}", $data);
  57. }
  58. public function post(Request $req, $name){
  59. $user=\Auth::user();
  60. $carbon=new \Carbon\Carbon;
  61. if($name=='apply_student_proposal'){
  62. $new_rules=[
  63. 'proposal_id'=>'required',
  64. ];
  65. $validator=\Validator::make($req->all(),$new_rules,[
  66. 'proposal_id.required'=>'No Proposal available.',
  67. 'startdate'=>'required',
  68. 'startmonth'=>'required',
  69. ]);
  70. if($validator->fails()){
  71. $errors=$validator->errors()->all();
  72. return response(['msg'=>$errors[0]], 422);
  73. }
  74. $already_exists = StudentProposal::where('student_id',$req->student_id)->exists();
  75. if($already_exists){
  76. return response(['msg'=>'Sorry! You already submitted. You can not submit proposal.'],403);
  77. }
  78. $publication =Publication::where('student_id',$req->student_id)->doesntExist();
  79. $worK_exp =Workexperience::where('student_id',$req->student_id)->doesntExist();
  80. $institution =Institution::where('student_id',$req->student_id)->doesntExist();
  81. $score =Score::where('student_id',$req->student_id)->doesntExist();
  82. if($publication || $worK_exp || $institution || $score){
  83. return response(['msg'=>'you didn\'t complete your profile.'],403);
  84. }
  85. $student_proposal =new StudentProposal;
  86. $student_proposal->student_id =$req->student_id;
  87. $student_proposal->teacher_id =$req->teacher_id;
  88. $student_proposal->proposal_id =$req->proposal_id;
  89. $student_proposal->start_year =$req->startdate;
  90. $student_proposal->start_month =$req->startmonth;
  91. $student_proposal->created_by =$user->id;
  92. $student_proposal->student_apply_ref =studentRefNoGenerate();
  93. $student_proposal->save();
  94. $user =User::find($student_proposal->student_id);
  95. $proposal_user =User::find($student_proposal->teacher_id);
  96. if($user){
  97. $data['name'] = $user->first_name.' '.$user->last_name;
  98. $data['teacher'] = $proposal_user->first_name.' '.$proposal_user->last_name;
  99. $data['arn'] = $proposal_user->ref_no;
  100. $user_mail =$user->email;
  101. $from = 'asraful@revinr.com';
  102. Mail::send('email.student_proposal_email',$data, function ($message) use ($user_mail,$from) {
  103. $message->from($from);
  104. $message->to($user_mail)->subject('Apply Ref:' .$student_proposal->student_apply_ref. '- Proposal has been submitted successfully ');
  105. });
  106. }
  107. $proposal =Proposal::where(
  108. 'student_id',$student_proposal->student_id
  109. )->where(
  110. 'id',$student_proposal->proposal_id
  111. )->first();
  112. if($proposal_user){
  113. $data['name'] = $proposal_user->first_name.' '.$proposal_user->last_name;
  114. $data['std_name'] = $user->first_name.' '.$user->last_name;
  115. $data['proposal_title'] =$proposal->title;
  116. $data['date_time']=$student_proposal->created_at;
  117. $user_mail =$proposal_user->email;
  118. $from = 'asraful@revinr.com';
  119. Mail::send('email.teacher_proposal_email',$data, function ($message) use ($user_mail,$from) {
  120. $message->from($from);
  121. $message->to($user_mail)->subject('New Email Send to you');
  122. });
  123. }
  124. return response(['msg'=>'Proposal send successfully.']);
  125. }elseif($name=="add_wishlist"){
  126. $user =Auth::guard('teacher')->user();
  127. $validator=\Validator::make($req->all(), [
  128. 'name'=>'required',
  129. 'email'=>'required|email|max:255|unique:users'
  130. ]);
  131. if($validator->fails()){
  132. $errors=$validator->errors()->all();
  133. return response(['msg'=>$errors[0]], 422);
  134. }
  135. $already_exists =User::where('email',$req->email)->exists();
  136. if($already_exists){
  137. return response(['msg'=>'Sorry! this email is already exists!.'],403);
  138. }
  139. $user_data =new User;
  140. $user_data->first_name =$req->name;
  141. $user_data->email =$req->email;
  142. $user_data->wishlist_teacher_id =$user->id;
  143. $user_data->user_type =1;
  144. $user_data->save();
  145. $refer =new ReferUser;
  146. $refer->name =$req->name;
  147. $refer->email =$req->email;
  148. $refer->refer_by =$user->id;
  149. $refer->teacher_id =$user->id;
  150. $refer->save();
  151. if($refer->save()){
  152. $data['name'] = $refer->name;
  153. $data['teacher_id'] = $refer->teacher_id;
  154. $data['student_id'] = $user_data->id;
  155. $data['std_email'] = $refer->email;
  156. $data['applicant_name'] = $user->first_name.' '.$user->last_name;
  157. $user_mail = $refer->email;
  158. $from = 'asraful@revinr.com';
  159. Mail::send('email.wishlist_email',$data, function ($message) use ($user_mail,$from) {
  160. $message->from($from);
  161. $message->to($user_mail)->subject('Research Admission Platform Sign-Up');
  162. });
  163. }
  164. return response(
  165. ['msg'=>'Refer saved successfully.']
  166. );
  167. }elseif($name=="teacher_invited"){
  168. $admin =Admin::find($req->id);
  169. $validator=\Validator::make($req->all(), [
  170. 'name'=>'required',
  171. 'email'=>'required|email|max:255|unique:users'
  172. ]);
  173. if($validator->fails()){
  174. $errors=$validator->errors()->all();
  175. return response(['msg'=>$errors[0]], 422);
  176. }
  177. $already_exists =User::where('email',$req->email)->exists();
  178. if($already_exists){
  179. return response(['msg'=>'Sorry! this email is already exists!.'],403);
  180. }
  181. $user_data =new User;
  182. $user_data->first_name =$req->name;
  183. $user_data->email =$req->email;
  184. $user_data->admin_invite_id =$admin->id;
  185. $user_data->user_type =2;
  186. $user_data->save();
  187. $refer =new ReferUser;
  188. $refer->name =$req->name;
  189. $refer->email =$req->email;
  190. $refer->refer_by =$admin->id;
  191. //$refer->teacher_id =$admin->id;
  192. $refer->save();
  193. if($refer->save()){
  194. $data['name'] = $refer->name;
  195. $data['teacher_id'] = $user_data->id;
  196. $data['applicant_name'] = $admin->first_name.' '.$admin->last_name;
  197. $user_mail = $refer->email;
  198. $from = 'asraful@revinr.com';
  199. Mail::send('email.teacher_invited_email',$data, function ($message) use ($user_mail,$from) {
  200. $message->from($from);
  201. $message->to($user_mail)->subject('Manage Doctoral Applicants with Ease - You’re invited!');
  202. });
  203. }
  204. return response(
  205. ['msg'=>'Invite saved successfully.']
  206. );
  207. }elseif($name=="add_doc_required"){
  208. $user=auth_user();
  209. $new_rules=[
  210. 'others'=>'required|array',
  211. 'others.*.requirement_title'=>'required',
  212. ];
  213. $validator=\Validator::make($req->all(),$new_rules,[
  214. 'others.*.requirement_title.required'=>'Please!, fill-up all requirement field.'
  215. ]);
  216. if($validator->fails()){
  217. $errors=$validator->errors()->all();
  218. return response(['msg'=>$errors[0]], 422);
  219. }
  220. $std_proposal=StudentProposal::find($req->id);
  221. foreach($req->others as $row){
  222. Requirement::create([
  223. 'std_proposal_id'=>$std_proposal->id,
  224. 'requirement_title'=>$row['requirement_title'],
  225. 'need_upload'=>$row['need_upload'],
  226. 'created_by'=>$user->id
  227. ]);
  228. }
  229. return response([
  230. 'msg'=>'Successfully Saved.'
  231. ]);
  232. }elseif($name=="edit_doc_required"){
  233. $requirements=Requirement::find($req->id);
  234. $requirements->requirement_title =$req->requirement_title;
  235. $requirements->need_upload =$req->need_upload;
  236. $requirements->update();
  237. return response([
  238. 'msg'=>'Successfully updated.'
  239. ]);
  240. }elseif($name=="landing_ragister_your_interest"){
  241. $validator=\Validator::make($req->all(), [
  242. 'name'=>'required',
  243. 'email'=>'required|email|max:255|unique:users'
  244. ]);
  245. if($validator->fails()){
  246. $errors=$validator->errors()->all();
  247. return response(['msg'=>$errors[0]], 422);
  248. }
  249. $already_exists =User::where('email',$req->email)->exists();
  250. if($already_exists){
  251. return response(['msg'=>'Sorry! this email is already exists!.'],403);
  252. }
  253. $user_data =new User;
  254. $user_data->first_name =$req->name;
  255. $user_data->email =$req->email;
  256. $user_data->nationality =$req->country_id;
  257. $user_data->university_name =$req->university_id;
  258. $user_data->uni_website =$req->uni_website;
  259. $user_data->user_type =2;
  260. $user_data->landing_register =1;
  261. $user_data->save();
  262. return response(
  263. ['msg'=>'Successfully saved.']
  264. );
  265. }
  266. return response(['msg'=>'No name argument found.'], 403);
  267. }
  268. }