] */ class CustomFieldsetsController extends Controller { public function index() { return redirect()->route("fields.index") ->with("error", trans('admin/custom_fields/message.fieldset.does_not_exist')); } /** * Validates and stores a new custom field. * * @author [Brady Wetherington] [] * @param int $id * @return \Illuminate\Support\Facades\View * @throws \Illuminate\Auth\Access\AuthorizationException * @since [v1.8] */ public function show($id) { $cfset = CustomFieldset::with('fields') ->where('id', '=', $id)->orderBy('id', 'ASC')->first(); $this->authorize('view', $cfset); if ($cfset) { $custom_fields_list = ['' => 'Add New Field to Fieldset'] + CustomField::pluck('name', 'id')->toArray(); $maxid = 0; foreach ($cfset->fields as $field) { if ($field->pivot->order > $maxid) { $maxid = $field->pivot->order; } if (isset($custom_fields_list[$field->id])) { unset($custom_fields_list[$field->id]); } } return view('custom_fields.fieldsets.view')->with('custom_fieldset', $cfset)->with('maxid', $maxid + 1)->with('custom_fields_list', $custom_fields_list); } return redirect()->route('fields.index') ->with('error', trans('admin/custom_fields/message.fieldset.does_not_exist')); } /** * Returns a view with a form for creating a new custom fieldset. * * @author [Brady Wetherington] [] * @since [v1.8] * @return \Illuminate\Support\Facades\View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function create() { $this->authorize('create', CustomField::class); return view('custom_fields.fieldsets.edit')->with('item', new CustomFieldset()); } /** * Validates and stores a new custom fieldset. * * @author [Brady Wetherington] [] * @since [v1.8] * @param Request $request * @return Redirect * @throws \Illuminate\Auth\Access\AuthorizationException */ public function store(Request $request) { $this->authorize('create', CustomField::class); $fieldset = new CustomFieldset([ 'name' => $request->get('name'), 'user_id' => Auth::user()->id, ]); $validator = Validator::make($request->all(), $fieldset->rules); if ($validator->passes()) { $fieldset->save(); // Sync fieldset with auto_add_to_fieldsets $fields = CustomField::select('id')->where('auto_add_to_fieldsets', '=', '1')->get(); if ($fields->count() > 0) { foreach ($fields as $field) { $field_ids[] = $field->id; } $fieldset->fields()->sync($field_ids); } return redirect()->route('fieldsets.show', [$fieldset->id]) ->with('success', trans('admin/custom_fields/message.fieldset.create.success')); } return redirect()->back()->withInput()->withErrors($validator); } /** * Presents edit form for fieldset * * @author [A. Gianotto] [] * @param int $id * @since [v6.0.14] * @return Redirect * @throws \Illuminate\Auth\Access\AuthorizationException */ public function edit($id) { $this->authorize('create', CustomField::class); if ($fieldset = CustomFieldset::find($id)) { return view('custom_fields.fieldsets.edit')->with('item', $fieldset); } return redirect()->route('fields.index')->with('error', trans('admin/custom_fields/general.fieldset_does_not_exist', ['id' => $id])); } /** * Saves updated fieldset data * * @author [A. Gianotto] [] * @param int $id * @since [v6.0.14] * @return Redirect * @throws \Illuminate\Auth\Access\AuthorizationException */ public function update(Request $request, $id) { $this->authorize('create', CustomField::class); if ($fieldset = CustomFieldset::find($id)) { $fieldset->name = $request->input('name'); if ($fieldset->save()) { return redirect()->route('fields.index')->with('success', trans('admin/custom_fields/general.fieldset_updated')); } return redirect()->back()->withInput()->withErrors($fieldset->getErrors()); } return redirect()->route('fields.index')->with('error', trans('admin/custom_fields/general.fieldset_does_not_exist', ['id' => $id])); } /** * Validates a custom fieldset and then deletes if it has no models associated. * * @author [Brady Wetherington] [] * @param int $id * @since [v1.8] * @return View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function destroy($id) { $fieldset = CustomFieldset::find($id); $this->authorize('delete', $fieldset); if ($fieldset) { $models = AssetModel::where('fieldset_id', '=', $id); if ($models->count() == 0) { $fieldset->delete(); return redirect()->route('fields.index')->with('success', trans('admin/custom_fields/message.fieldset.delete.success')); } return redirect()->route('fields.index')->with('error', trans('admin/custom_fields/message.fieldset.delete.in_use')); } return redirect()->route('fields.index')->with('error', trans('admin/custom_fields/message.fieldset.does_not_exist')); } /** * Associate the custom field with a custom fieldset. * * @author [Brady Wetherington] [] * @since [v1.8] * @return View */ public function associate(Request $request, $id) { $set = CustomFieldset::find($id); $this->authorize('update', $set); if ($request->filled('field_id')) { foreach ($set->fields as $field) { if ($field->id == $request->input('field_id')) { return redirect()->route('fieldsets.show', [$id])->withInput()->withErrors(['field_id' => trans('admin/custom_fields/message.field.already_added')]); } } $results = $set->fields()->attach($request->input('field_id'), ['required' => ($request->input('required') == 'on'), 'order' => (int)$request->input('order', 1)]); return redirect()->route('fieldsets.show', [$id])->with('success', trans('admin/custom_fields/message.field.create.assoc_success')); } return redirect()->route('fieldsets.show', [$id])->with('error', 'No field selected.'); } /** * Set the field in a fieldset to required * * @author [A. Gianotto] [] * @since [v5.0] */ public function makeFieldRequired($fieldset_id, $field_id) { $this->authorize('update', CustomField::class); $field = CustomField::findOrFail($field_id); $fieldset = CustomFieldset::findOrFail($fieldset_id); $fields[$field->id] = ['required' => 1]; $fieldset->fields()->syncWithoutDetaching($fields); return redirect()->route('fieldsets.show', ['fieldset' => $fieldset_id]) ->with('success', trans('Field successfully set to required')); } /** * Set the field in a fieldset to optional * * @author [A. Gianotto] [] * @since [v5.0] */ public function makeFieldOptional($fieldset_id, $field_id) { $this->authorize('update', CustomField::class); $field = CustomField::findOrFail($field_id); $fieldset = CustomFieldset::findOrFail($fieldset_id); $fields[$field->id] = ['required' => 0]; $fieldset->fields()->syncWithoutDetaching($fields); return redirect()->route('fieldsets.show', ['fieldset' => $fieldset_id]) ->with('success', trans('Field successfully set to optional')); } }