ModalController.php 11 KB

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