where('outcome_id', $outcome_id);
}
if($program_id)
{
$objectives->where('program_id', $program_id);
}
if($format == 'select')
{
$string = '';
foreach ($objectives->get() as $objective)
{
$string.='';
}
echo $string;
return;
}
else
{
return $objectives->get();
}
}
catch (Exception $e)
{
echo $e->getMessage();
return;
}
}
/**
* Edit the learning objectives per learning outcome for a program
*/
public function index($program)
{
$role = Auth::user()->role;
// Redirect users if they try to access forbidden page
if($role == 2 && $program->school_id != Auth::user()->school_id)
{
return Redirect::to('/');
}
else if($role == 3 && !in_array($program->id, Auth::user()->programs->lists('id')))
{
return Redirect::to('/');
}
else if($role == 4)
{
return Redirect::to('/');
}
$title = 'Learning Objectives ('.$program->name.')';
$objectives = $program->objectives;
// Eager load outcomes related to objectives
// $program->load('outcomes');
//
$outcomes = Outcome::select('id', 'name')->get();
return View::make('local.managers.shared.objectives.index', compact('title', 'objectives', 'role', 'program', 'outcomes'));
}
public function create()
{
try
{
$outcome_id = Input::get('outcome_id');
$program_id = Input::get('program_id');
$learning_objective = trim(Input::get('learning_objective'));
$validator = Validator::make(
array(
'outcome_id' => $outcome_id,
'program_id' => $program_id,
'learning_objective' => $learning_objective
),
array(
'outcome_id' => 'required|integer',
'program_id' => 'required|integer',
'learning_objective' => 'required|min:1',
)
);
if($validator->fails())
{
/** Prepare error message */
$message = '
Error(s) creating a new Learning Objective:
';
foreach ($validator->messages()->all('- :message
') as $validationError)
{
$message.=$validationError;
}
$message.='
';
/** Send error message and old data */
Session::flash('status', 'danger');
Session::flash('message', $message);
return Redirect::back()->withInput();
}
DB::table('objectives')->insert(array(
'outcome_id' => $outcome_id,
'program_id' => $program_id,
'text' => $learning_objective
));
/** Send success message */
Session::flash('status', 'success');
Session::flash('message', 'New Learning Objective successfully created.');
return Redirect::back();
}
catch(Exception $e)
{
/** Send error message and old data */
Session::flash('status', 'danger');
Session::flash('message', 'An error ocurred trying to create a new Learning Objective. Please try again later.'.$e->getMessage());
return Redirect::back()->withInput();
}
}
/**
* Update objective
*/
public function update()
{
try
{
$outcome_id = Input::get('edit_outcome_id');
$objective_id = Input::get('edit_objective_id');
$active = Input::get('edit_active');
$learning_objective = trim(Input::get('edit_learning_objective'));
$validator = Validator::make(
array(
'outcome_id' => $outcome_id,
'objective_id' => $objective_id,
'active' => $active,
'learning_objective' => $learning_objective
),
array(
'outcome_id' => 'required|integer',
'objective_id' => 'required|integer',
'active' => 'required|integer|boolean',
'learning_objective' => 'required|min:1',
)
);
if($validator->fails())
{
/** Prepare error message */
$message = 'Error(s) updating the Learning Objective:
';
foreach ($validator->messages()->all('- :message
') as $validationError)
{
$message.=$validationError;
}
$message.='
';
/** Send error message and old data */
Session::flash('status', 'danger');
Session::flash('message', $message);
return Redirect::back()->withInput();
}
DB::table('objectives')
->where('id', $objective_id)
->update(array(
'outcome_id' => $outcome_id,
'text' => $learning_objective,
'active' => $active,
));
/** Send success message */
Session::flash('status', 'success');
Session::flash('message', 'Learning Objective successfully updated.');
return Redirect::back();
}
catch(Exception $e)
{
/** Send error message and old data */
Session::flash('status', 'danger');
Session::flash('message', 'An error ocurred trying to create a new Learning Objective. Please try again later.'.$e->getMessage());
return Redirect::back()->withInput();
}
}
/**
* Check what this was for
* @return [type] [description]
*/
public function fetchObjective()
{
$validator = Validator::make(
array(
'objective_id' => Input::get('objective_id')
),
array(
'objective_id' => 'required|integer',
)
);
if($validator->fails())
{
return '';
}
$res = DB::table('objectives')->where('id', Input::get('objective_id'))->first();
return json_encode($res);
}
public function fetchObjectiveForCriteria()
{
$id = Input::get('id');
$objective = Objective::find($id);
$objective->program;
$objective->criteria;
return array
(
'objective' => $objective
);
}
}