ENTITY_CREDIT, 'title' => '- Credits', 'columns'=>['checkbox', 'Client', 'Credit Amount', 'Credit Date', 'Action'] )); } public function getDatatable($clientPublicId = null) { $query = DB::table('credits') ->join('clients', 'clients.id', '=','credits.client_id') ->where('clients.account_id', '=', Auth::user()->account_id) ->where('clients.deleted_at', '=', null) ->where('credits.deleted_at', '=', null) ->select('credits.public_id', 'clients.name as client_name', 'clients.public_id as client_public_id', 'credits.amount', 'credits.credit_date', 'credits.currency_id'); if ($clientPublicId) { $query->where('clients.public_id', '=', $clientPublicId); } $filter = Input::get('sSearch'); if ($filter) { $query->where(function($query) use ($filter) { $query->where('clients.name', 'like', '%'.$filter.'%'); }); } $table = Datatable::query($query); if (!$clientPublicId) { $table->addColumn('checkbox', function($model) { return ''; }) ->addColumn('client_name', function($model) { return link_to('clients/' . $model->client_public_id, $model->client_name); }); } return $table->addColumn('amount', function($model){ return Utils::formatMoney($model->amount, $model->currency_id); }) ->addColumn('credit_date', function($model) { return Utils::fromSqlDate($model->credit_date); }) ->addColumn('dropdown', function($model) { return ''; }) ->orderColumns('number') ->make(); } public function create($clientPublicId = null) { $client = null; if ($clientPublicId) { $client = Client::scope($clientPublicId)->firstOrFail(); } $data = array( 'client' => $client, 'credit' => null, 'method' => 'POST', 'url' => 'credits', 'title' => '- New Credit', 'currencies' => Currency::orderBy('name')->get(), 'clients' => Client::scope()->orderBy('name')->get()); return View::make('credits.edit', $data); } public function edit($publicId) { $credit = Credit::scope($publicId)->firstOrFail(); $data = array( 'client' => null, 'credit' => $credit, 'method' => 'PUT', 'url' => 'credits/' . $publicId, 'title' => '- Edit Credit', 'currencies' => Currency::orderBy('name')->get(), 'clients' => Client::scope()->orderBy('name')->get()); return View::make('credit.edit', $data); } public function store() { return $this->save(); } public function update($publicId) { return $this->save($publicId); } private function save($publicId = null) { $rules = array( 'client' => 'required', 'amount' => 'required' ); $validator = Validator::make(Input::all(), $rules); if ($validator->fails()) { $url = $publicId ? 'credits/' . $publicId . '/edit' : 'credits/create'; return Redirect::to($url) ->withErrors($validator) ->withInput(); } else { if ($publicId) { $credit = Credit::scope($publicId)->firstOrFail(); } else { $credit = Credit::createNew(); } $credit->client_id = Input::get('client'); $credit->credit_date = Utils::toSqlDate(Input::get('credit_date')); $credit->amount = floatval(Input::get('amount')); $credit->currency_id = Input::get('currency_id') ? Input::get('currency_id') : null; $credit->save(); $message = $publicId ? 'Successfully updated credit' : 'Successfully created credit'; Session::flash('message', $message); return Redirect::to('clients/' . $credit->client_id); } } public function bulk() { $action = Input::get('action'); $ids = Input::get('id') ? Input::get('id') : Input::get('ids'); $credits = Credit::scope($ids)->get(); foreach ($credits as $credit) { if ($action == 'delete') { $credit->is_deleted = true; $credit->save(); } $credit->delete(); } $message = Utils::pluralize('Successfully '.$action.'d ? credit', count($credits)); Session::flash('message', $message); return Redirect::to('credits'); } }