middleware('admin'); $this->userRepo = $userRepo; } /** * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function index() { $data = [ 'values' => User::where('admin', '=', 0)->where('confirmation_code_remider', '!=', 2)->get(), ]; return view('admin.lead.index', $data); } /** * @param $id * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function edit($id) { if($id === "new"){ $user = new User(); $user->account = new UserAccount(); $user->account->same_as_billing = 1; $user->account->country_id = 1; $user->account->shipping_country_id = 1; $user->id = "new"; }else{ $user = User::findOrFail($id); if(!$user->account){ $user->account = new UserAccount(); } } $data = [ 'show' => Input::get('show'), 'user' => $user, 'can_change_mail' => true, 'm_data_load' => false, 'm_data_error' => false, ]; return view('admin.lead.edit', $data); } /** * @param $id * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View */ public function editPost($id) { $m_data_load = false; $m_data_error = false; $data = Input::all(); if(!isset($data['edit_m_data_key']) && $data['edit_m_data_key'] !== "mivita"){ $m_data_error = "Der Key ist falsch."; }else{ $m_data_load = true; } if($id === "new"){ $user = new User(); $user->account = new UserAccount(); $user->account->same_as_billing = 1; $user->account->country_id = 1; $user->account->shipping_country_id = 1; $user->id = "new"; }else{ $user = User::findOrFail($id); if(!$user->account){ $user->account = new UserAccount(); } } $data = [ 'show' => Input::get('show'), 'user' => $user, 'm_data_load' => $m_data_load, 'm_data_error' => $m_data_error, 'can_change_mail' => true, ]; return view('admin.lead.edit', $data); } /** * @param Request $request * @return \Illuminate\Contracts\View\Factory|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector|\Illuminate\View\View */ public function store(Request $request) { $data = Input::all(); $show = Input::get('show'); if ($data['user_id'] === "new" || $data['user_id'] == 0) { $rules = array( 'salutation' => 'required', 'first_name'=>'required', 'last_name'=>'required', 'email' => 'required|string|email|max:255|unique:users', 'email-confirm' => 'required|same:email', ); }else{ $rules = array( 'salutation' => 'required', 'first_name'=>'required', 'last_name'=>'required', 'address'=>'required', 'zipcode'=>'required', 'city' => 'required', 'email' => 'required|string|email|max:255|exists:users,email', 'email-confirm' => 'required|same:email', ); if(!Input::get('same_as_billing')){ $rules = array_merge($rules, [ 'shipping_firstname'=>'required', 'shipping_lastname'=>'required', 'shipping_address'=>'required', 'shipping_zipcode'=>'required', 'shipping_city' => 'required', 'shipping_salutation' => 'required' ]); } } $validator = Validator::make(Input::all(), $rules); if ($validator->fails()) { if ($data['user_id'] === "new" || $data['user_id'] == 0) { $user_id = "new"; }else{ $user = User::findOrFail($data['user_id']); $user_id = $user->id; } return redirect(route('admin_lead_edit', [$user_id]))->withErrors($validator)->withInput(Input::all()); } if ($data['user_id'] === "new" || $data['user_id'] == 0) { $user = new User(); $user->id = "new"; $user->account = new UserAccount(); }else { $user = User::findOrFail($data['user_id']); if(!$user->account){ $user->account = new UserAccount(); } } $this->userRepo->update($data); if(isset($data['m_data_edit']) && $data['m_data_edit'] === "TSOK"){ $user = $this->userRepo->getModel(); $user->m_level = isset($data['m_level']) ? $data['m_level'] : NULL; $user->m_sponsor = isset($data['m_sponsor']) ? $data['m_sponsor'] : NULL; $user->save(); } if(isset($data['contact_verify'])){ $user = $this->userRepo->getModel(); $unique = false; do{ $confirmation_code = str_random(30); if( User::where('confirmation_code', '=', $confirmation_code)->count() == 0){ $unique = true; } } while(!$unique); $user->lang = $user->getLandByCountry(); $user->confirmation_code = $confirmation_code; //10 == start wizard form create Lead $user->wizard = 10; $user->save(); Mail::to($user->email)->send(new MailVerifyContact($confirmation_code, $user)); \Session()->flash('alert-save', true); return redirect(route('admin_leads')); } \Session()->flash('alert-save', true); return redirect(route('admin_lead_edit', [$user->id])."?show=".$show); } //user released when register is complete public function newReleased($id){ $user = User::findOrFail($id); $validator = Validator::make(Input::all(), []); if(!$user->m_sponsor){ $validator->errors()->add('m_sponsor', __('Berater hat keinen Sponsor.')); } if(!$user->account->m_first_name){ $validator->errors()->add('m_first_name', __('Berater hat keinen Vornamen.')); } if(!$user->account->m_first_name){ $validator->errors()->add('m_last_name', __('Berater hat keinen Nachnamen.')); } if(!$user->account->m_account){ $validator->errors()->add('m_account', __('Berater hat keine Account ID')); } if ($validator->errors()->count()) { return back()->withErrors($validator)->withInput(Input::all()); } //create PDF $pdf = new ContractPDFRepository($user); $pdf->_set('disk', 'user'); $pdf->_set('dir', '/'.$user->id.'/documents/'); $pdf->_set('user_id', $user->id); $pdf->_set('identifier', 'contract'); $pdf->createContractPDF(); //set wizard tp payments $user->wizard = 20; $user->active = 1; $user->active_date = now(); $user->confirmation_code = null; $user->confirmation_code_to = null; $user->confirmation_code_remider = 0; $user->save(); //mail with code to user? Mail::to($user->email)->send(new MailAccountActive($user)); \Session()->flash('alert-success', "Berater freigeschaltet!"); return redirect(route('admin_lead_edit', [$user->id])); } //send new verfified mail to user public function newMailVerified($id){ $user = User::findOrFail($id); $unique = false; do{ $confirmation_code = str_random(30); if(User::where('confirmation_code', '=', $confirmation_code)->count() == 0){ $unique = true; } } while(!$unique); $user->confirmation_code = $confirmation_code; $user->confirmation_code_to = date('Y-m-d H:i:s', strtotime('+1 week')); $user->confirmation_code_remider = 0; $user->save(); Mail::to($user->email)->send(new MailVerifyAccount($confirmation_code, $user)); \Session()->flash('alert-success', "E-Mail erneut gesendet"); return redirect(route('admin_lead_edit', [$user->id])); } public function getLeads() { $query = User::with('account')->where('users.deleted_at', '=', null); return \DataTables::eloquent($query) ->addColumn('first_name', function (User $user) { return $user->account ? $user->account->first_name : ''; }) ->addColumn('last_name', function (User $user) { return $user->account ? $user->account->last_name : ''; }) ->addColumn('id', function (User $user) { return ''; }) ->addColumn('confirmed', function (User $user) { return $user->confirmed ? '' : ''; }) ->addColumn('active', function (User $user) { return $user->active ? ' ' : ''; }) ->addColumn('agreement', function (User $user) { return $user->agreement ? ' ' : ''; }) ->addColumn('payment_account', function (User $user) { return $user->payment_account ? ' ' : ''; }) ->addColumn('payment_account_date', function (User $user) { return $user->payment_account ? $user->getPaymentAccountDateFormat(false) : "-"; }) ->addColumn('payment_shop', function (User $user) { return $user->payment_shop ? ' ' : ''; }) ->addColumn('payment_shop_date', function (User $user) { return $user->payment_shop ? $user->getPaymentShopDateFormat(false) : "-"; }) ->addColumn('turnover', function (User $user) { return "-"; }) ->addColumn('sales_total', function (User $user) { return "-"; }) ->orderColumn('id', 'id $1') ->orderColumn('confirmed', 'confirmed $1') ->orderColumn('active', 'active $1') ->orderColumn('agreement', 'agreement $1') ->orderColumn('payment_account', 'payment_account $1') ->orderColumn('payment_shop', 'payment_shop $1') ->rawColumns(['id', 'confirmed', 'active', 'agreement', 'payment_account', 'payment_shop']) ->make(true); } }