Files
faveo/app/Http/Controllers/Admin/helpdesk/FormController.php
Manish Verma 2d8e640e9b Updates
2016-12-13 18:18:25 +05:30

600 lines
22 KiB
PHP

<?php
namespace App\Http\Controllers\Admin\helpdesk;
// Controller
use App\Http\Controllers\Controller;
// Model
use App\Model\helpdesk\Form\Fields;
use App\Model\helpdesk\Form\Forms;
use App\Model\helpdesk\Manage\Help_topic;
// Request
use Illuminate\Http\Request;
// Class
use Input;
use Lang;
use Redirect;
use Exception;
use Form;
/**
* FormController
* This controller is used to CRUD Custom Forms.
*
* @author Ladybird <info@ladybirdweb.com>
*/
class FormController extends Controller {
private $fields;
private $forms;
public function __construct(Fields $fields, Forms $forms) {
$this->fields = $fields;
$this->forms = $forms;
$this->middleware('auth', [
'except' => [
'renderForm',
'getType',
'getAttribute',
'getForm',
'createValues',
'addChild',
'renderChild',
'jqueryScript',
'jqueryCheckboxScript',
'jquerySelectScript',
]
]);
}
/**
* home.
*
* @return type
*/
public function home() {
return view('forms.home');
}
/**
* list of forms.
*
* @param type Forms $forms
*
* @return Response
*/
public function index(Forms $forms) {
try {
return view('themes.default1.admin.helpdesk.manage.form.index', compact('forms'));
} catch (Exception $e) {
return redirect()->back()->with('fails', $e->getMessage());
}
}
/**
* create a new form.
*
* @return Response
*/
public function create() {
try {
return view('themes.default1.admin.helpdesk.manage.form.form');
} catch (Exception $e) {
return redirect()->back()->with('fails', $e->getMessage());
}
}
/**
* Show a new form.
*
* @param int $id
*
* @return Response
*/
public function show($id) {
try {
$forms = new Forms();
$form = $forms->find($id);
//dd($form);
if ($form) {
$fields = $form->fields();
return view('themes.default1.admin.helpdesk.manage.form.preview', compact('form', 'fields'));
}
throw new Exception("Sorry we can't find your request");
} catch (Exception $ex) {
return redirect()->back()->with('fails', $ex->getMessage());
}
}
/**
* Store a new form.
*
* @return Response
*/
public function store(Request $request) {
$this->validate($request, [
'formname' => 'required|unique:custom_forms,formname',
'label.*' => 'required',
'name.*' => 'required',
'type.*' => 'required',
]);
try {
$forms = new Forms();
$require = Input::get('required');
$forms->formname = Input::get('formname');
$forms->save();
$count = count(Input::get('name'));
$fields = [];
for ($i = 0; $i <= $count; $i++) {
if (!empty(Input::get('name')[$i])) {
$name = str_slug(Input::get('name')[$i], '_');
$field = Fields::create([
'forms_id' => $forms->id,
'label' => Input::get('label')[$i],
'name' => $name,
'type' => Input::get('type')[$i],
'required' => $require[$i],
]);
$field_id = $field->id;
$this->createValues($field_id, Input::get('value')[$i],null,$name);
}
}
return Redirect::back()->with('success', Lang::get('lang.successfully_created_form'));
} catch (Exception $ex) {
dd($ex);
return redirect()->back()->with('fails', $ex->getMessage());
}
}
/**
* Delete Form.
*
* @param type $id
* @param \App\Model\helpdesk\Form\Forms $forms
* @param type $field
* @param type $help_topic
*
* @return type redirect
*/
public function delete($id, Forms $forms, Fields $field, Help_topic $help_topic) {
$fields = $field->where('forms_id', $id)->get();
$help_topics = $help_topic->where('custom_form', '=', $id)->get();
foreach ($help_topics as $help_topic) {
$help_topic->custom_form = null;
$help_topic->save();
}
foreach ($fields as $field) {
$field->delete();
}
$forms = $forms->where('id', $id)->first();
$forms->delete();
return redirect()->back()->with('success', Lang::get('lang.form_deleted_successfully'));
}
public function edit($id) {
try {
$forms = new Forms();
$form = $forms->find($id);
$select_forms = $forms->where('id', '!=', $id)->lists('formname', 'id')->toArray();
//dd($form);
if ($form) {
$fields = $form->fields();
//dd($fields);
return view('themes.default1.admin.helpdesk.manage.form.edit', compact('form', 'fields', 'select_forms'));
}
throw new Exception("Sorry we can't find your request");
} catch (Exception $ex) {
return redirect()->back()->with('fails', $ex->getMessage());
}
}
public function addChildForm($id) {
try {
$forms = new Forms();
$form = $forms->find($id);
$select_forms = $forms->where('id', '!=', $id)->lists('formname', 'id')->toArray();
//dd($form);
if ($form) {
$fields = $form->fields();
//dd($fields);
return view('themes.default1.admin.helpdesk.manage.form.add-child', compact('form', 'fields', 'select_forms'));
}
throw new Exception("Sorry we can't find your request");
} catch (Exception $ex) {
return redirect()->back()->with('fails', $ex->getMessage());
}
}
public function update($id, Request $request) {
$this->validate($request, [
'formname' => 'required|unique:custom_forms,formname,' . $id,
'label.*' => 'required',
'name.*' => 'required',
'type.*' => 'required',
]);
try {
if (!$request->input('formname')) {
throw new Exception(Lang::get('lang.please_fill_form_name'));
}
$form = new Forms();
$forms = $form->find($id);
if (!$forms) {
throw new Exception("Sorry we can not find your request");
}
$forms->formname = Input::get('formname');
$forms->save();
$count = count(Input::get('name'));
$field = new Fields();
$fields = $field->where('forms_id', $forms->id)->get();
if ($fields->count($fields) > 0) {
foreach ($fields as $fi) {
$fi->delete();
}
}
//dd(Input::get('label'),Input::get('name'),Input::get('type'),Input::get('required'));
for ($i = 0; $i < $count; $i++) {
$name = str_slug(Input::get('name')[$i], '_');
$field = $field->create([
'forms_id' => $forms->id,
'label' => Input::get('label')[$i],
'name' => $name,
'type' => Input::get('type')[$i],
'required' => Input::get('required')[$i],
]);
$field_id = $field->id;
$this->createValues($field_id, Input::get('value')[$i],null,$name);
}
return redirect()->back()->with('success', 'updated');
} catch (Exception $ex) {
dd($ex);
return redirect()->back()->with('fails', $ex->getMessage());
}
}
public function renderForm($formid) {
$html = "";
$forms = new Forms();
$form = $forms->find($formid);
if ($form) {
$fields = $form->fields();
foreach ($fields as $field) {
$html .= self::getForm($field);
}
}
return self::requiredStyle() . $html;
}
public static function getType($type) {
switch ($type) {
case "select":
return "select";
case "text":
return "text";
case "email":
return "email";
case "textarea":
return "textarea";
case "select":
return "select";
case "radio":
return "radio";
case "checkbox":
return "checkbox";
case "hidden":
return "hidden";
case "password":
return "password";
}
}
public static function getAttribute($type) {
switch ($type) {
case "select":
return "null,['class'=>'form-control']";
case "text":
return "['class'=>'form-control']";
case "email":
return "['class'=>'form-control']";
case "textarea":
return "['class'=>'form-control']";
case "radio":
return "";
case "checkbox":
return "";
case "hidden":
return "";
case "password":
return "['class'=>'form-control']";
}
}
public static function getForm($field) {
$required = false;
$required_class = self::requiredClass($field->required);
if ($field->required === '1') {
$required = true;
}
$type = $field->type;
$field_type = self::getType($type);
switch ($field_type) {
case "select":
return self::selectForm($field_type, $field, $required, $required_class);
case "text":
return Form::label($field->label, $field->label, ['class' => $required_class]) .
Form::$field_type($field->name, NULL, ['class' => "form-control $field->id", 'id' => $field->id, 'required' => $required]);
case "email":
return Form::label($field->label, $field->label, ['class' => $required_class]) .
Form::$field_type($field->name, NULL, ['class' => "form-control $field->id", 'id' => $field->id, 'required' => $required]);
case "password":
return Form::label($field->label, $field->label, ['class' => $required_class]) .
Form::$field_type($field->name, ['class' => "form-control $field->id", 'id' => $field->id, 'required' => $required]);
case "textarea":
return Form::label($field->label, $field->label, ['class' => $required_class]) .
Form::$field_type($field->name, NULL, ['class' => "form-control $field->id", 'id' => $field->id, 'required' => $required]);
case "radio":
return self::radioForm($field_type, $field, $required, $required_class);
case "checkbox":
return self::checkboxForm($field_type, $field, $required, $required_class);
case "hidden":
return Form::$field_type($field->name, NULL, ['id' => $field->id]);
}
}
public function createValues($fieldid, $values, $childid = NULL, $key = "") {
if ($values) {
$values_array = explode(',', $values);
$field_values = new \App\Model\helpdesk\Form\FieldValue();
$field_value = $field_values->where('field_id', $fieldid)->get();
if ($field_value->count() > 0) {
foreach ($field_value as $fv) {
$fv->delete();
}
}
if (count($values_array) > 0) {
foreach ($values_array as $value) {
$field_values->create([
'field_id' => $fieldid,
'child_id' => $childid,
'field_key' => $key,
'field_value' => str_slug($value, '_'),
]);
}
}
}
}
public function addChild($fieldid, Request $request) {
$ids = $request->except('_token');
try {
foreach ($ids as $valueid => $formid) {
$field_value = new \App\Model\helpdesk\Form\FieldValue();
$field_values = $field_value->where('field_id', $fieldid);
$values = $field_values->where('id', $valueid)->first();
if ($values) {
//if ($formid) {
$values->child_id = $formid;
$values->save();
//}
}
}
return redirect()->back()->with('success', 'Updated');
} catch (Exception $ex) {
return redirect()->back()->with('fails', $ex->getMessage());
}
}
public function renderChild(Request $request) {
self::setSession();
$render = "";
$value = $request->input('valueid');
$fieldid = $request->input('fieldid');
$field_values = new \App\Model\helpdesk\Form\FieldValue();
$field_value = $field_values->where('field_id', $fieldid)->where('field_value', $value)->first();
$child = "";
if ($field_value) {
$child = $field_value->child_id;
}
if ($child !== "") {
$render = $this->renderForm($child);
}
return $render;
}
public static function jqueryScript($value, $fieldid, $fieldname, $type = "", $index = "") {
if ($type == "select") {
return self::jquerySelectScript($fieldid);
}
if ($type == "checkbox") {
return self::jqueryCheckboxScript($fieldid, $index);
}
return '<script>
$("#' . str_slug($value) . '").on("change", function () {
var valueid = $("#' . str_slug($value) . '").val();
var fieldid = $("#' . $fieldid . str_slug($value) . '").val();
send' . $fieldid . str_slug($value) . '(valueid,fieldid);
});
function send' . $fieldid . str_slug($value) . '(valueid,fieldid) {
$.ajax({
url: "' . url('forms/render/child/') . '",
dataType: "html",
data: {"valueid": valueid,"fieldid": fieldid},
success: function (response) {
$("#' . $fieldname . '").html(response);
},
error: function (response) {
$("#' . $fieldname . '").html(response);
}
});
}
</script>';
}
public static function jqueryCheckboxScript($fieldid, $index) {
$session = self::getSession();
$fields = new Fields();
$field = $fields->find($fieldid);
if ($field) {
return '<script>
$("#' . $session . $index . '").on("change", function () {
var valueid = $("#' . $session . $index . '").val();
var fieldid = $("#f' . $session . $index . '").val();
if($(this).is(":checked")) {
send' . $session . $index . '(valueid,fieldid);
}else{
$("#div' . $session . '"+valueid).empty();
}
});
function send' . $session . $index . '(valueid,fieldid) {
$.ajax({
url: "' . url('forms/render/child/') . '",
dataType: "html",
data: {"valueid": valueid,"fieldid": fieldid},
success: function (response) {
$("#div' . $session . '"+valueid).html(response);
},
error: function (response) {
$("#div' . $session . '"+valueid).html(response);
}
});
}
</script>';
}
}
public static function jquerySelectScript($fieldid) {
$fields = new Fields();
$field = $fields->find($fieldid);
$session = self::getSession();
if ($field) {
return '<script>
$(document).ready(function () {
var valueid = $(".' . $session . $fieldid . '").val();
var fieldid = $("#hidden' . $session . $fieldid . '").val();
send' . $session . $fieldid . '(valueid,fieldid);
$(".' . $session . $fieldid . '").on("change", function () {
valueid = $(".' . $session . $fieldid . '").val();
var fieldid = $("#hidden' . $session . $fieldid . '").val();
send' . $session . $fieldid . '(valueid,fieldid);
});
function send' . $session . $fieldid . '(valueid,fieldid) {
$.ajax({
url: "' . url('forms/render/child/') . '",
dataType: "html",
data: {"valueid": valueid,"fieldid": fieldid},
success: function (response) {
$("#' . $session . $field->name . '").html(response);
},
error: function (response) {
$("#' . $session . $field->name . '").html(response);
}
});
}
});
</script>';
}
}
public static function selectForm($field_type, $field, $required, $required_class) {
$session = self::getSession();
$script = self::jqueryScript($field_value = "", $field->id, $field->name, $field_type);
$form_hidden = Form::hidden('fieldid[]', $field->id, ['id' => "hidden" . $session . $field->id]) . Form::label($field->label, $field->label, ['class' => $required_class]);
$select = Form::$field_type($field->name, ['' => 'Select', 'Selects' => self::removeUnderscoreFromDB($field->values()->lists('field_value', 'field_value')->toArray())], null, ['class' => "form-control $session$field->id", 'id' => $session . $field->id, 'required' => $required]) . "</br>";
$html = $script . $form_hidden . $select;
$response_div = "<div id=" . $session . $field->name . "></div>";
return $html . $response_div;
}
public static function radioForm($field_type, $field, $required, $required_class) {
$radio = "";
$html = "";
$values = $field->values()->lists('field_value')->toArray();
if (count($values) > 0) {
foreach ($values as $field_value) {
$script = self::jqueryScript($field_value, $field->id, $field->name, $field_type);
$radio .= "<div>" . Form::hidden('fieldid[]', $field->id, ['id' => $field->id . str_slug($field_value)]);
$radio .= Form::$field_type($field->name, $field_value, NULL, ['class' => "$field->id", 'id' => str_slug($field_value), 'required' => $required]) . $script . "<span> " . removeUnderscore($field_value) . "</span></div>";
}
$html = Form::label($field->label, $field->label, ['class' => $required_class]) . "</br>" . $radio . "<div id=" . $field->name . "></br></div>";
}
return $html;
}
public static function checkboxForm($field_type, $field, $required, $required_class) {
$session = self::getSession();
$checkbox = "";
$html = "";
$values = $field->values()->lists('field_value')->toArray();
if (count($values) > 0) {
$i = 1;
foreach ($values as $field_value) {
$script = self::jqueryScript($field_value, $field->id, $field->name, $field_type, $i);
$checkbox .= Form::hidden('fieldid[]', $field->id, ['id' => 'f' . $session . $i]);
$checkbox .= Form::$field_type($field->name, $field_value, NULL, ['class' => "$field->id", 'id' => $session . $i, 'required' => $required]);
$checkbox .= "<span> " . removeUnderscore($field_value) . "</span>";
//$checkbox .="</br>";
$checkbox .="<div>" . $script . "<div id=div" . $session . $field_value . "></div></div>";
$i++;
}
$html = Form::label($field->label, $field->label, ['class' => $required_class]) . "</br>" . $checkbox;
}
return $html;
}
public static function requiredStyle() {
$style = "<style>
.required:after {
color: #e32 !important;
content: ' * ' !important;
display:inline !important;
}
</style>";
return $style;
}
public static function requiredClass($required) {
$class = "";
if ($required === '1') {
$class = "required";
}
return $class;
}
public static function setSession() {
$form = self::getSession();
$form++;
\Session::set('fromid', $form);
}
public static function getSession() {
$form = 0;
if (\Session::has('fromid')) {
$form = \Session::get('fromid');
}
return $form;
}
public static function removeUnderscoreFromDB($array) {
$result = [];
if (is_array($array) && count($array) > 0) {
foreach ($array as $key => $value) {
$result[$key] = removeUnderscore($value);
}
}
return $result;
}
}