SettingsController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Contracts\Foundation\Application;
  5. use Illuminate\Contracts\View\Factory;
  6. use Illuminate\Contracts\View\View;
  7. use Illuminate\Http\Response;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\Redirect;
  10. use Illuminate\Support\Facades\Validator;
  11. use Qirolab\Theme\Theme;
  12. class SettingsController extends Controller
  13. {
  14. /**
  15. * Display a listing of the resource.
  16. *
  17. * @return Application|Factory|View|Response
  18. */
  19. public function index()
  20. {
  21. // get all other settings in app/Settings directory
  22. // group items by file name like $categories
  23. $settings = collect();
  24. foreach (scandir(app_path('Settings')) as $file) {
  25. if (in_array($file, ['.', '..'])) {
  26. continue;
  27. }
  28. $className = 'App\\Settings\\' . str_replace('.php', '', $file);
  29. $options = (new $className())->toArray();
  30. if (method_exists($className, 'getOptionInputData')) {
  31. $optionInputData = $className::getOptionInputData();
  32. } else {
  33. $optionInputData = [];
  34. }
  35. $optionsData = [];
  36. foreach ($options as $key => $value) {
  37. $optionsData[$key] = [
  38. 'value' => $value,
  39. 'label' => $optionInputData[$key]['label'] ?? ucwords(str_replace('_', ' ', $key)),
  40. 'type' => $optionInputData[$key]['type'] ?? 'string',
  41. 'description' => $optionInputData[$key]['description'] ?? '',
  42. 'options' => $optionInputData[$key]['options'] ?? [],
  43. ];
  44. }
  45. $settings[str_replace('Settings.php', '', $file)] = $optionsData;
  46. }
  47. $settings->sort();
  48. $themes = array_diff(scandir(base_path('themes')), array('..', '.'));
  49. return view('admin.settings.index', [
  50. 'settings' => $settings->all(),
  51. 'themes' => $themes,
  52. 'active_theme' => Theme::active(),
  53. ]);
  54. }
  55. /**
  56. * Update the specified resource in storage.
  57. *
  58. */
  59. public function update(Request $request)
  60. {
  61. $category = request()->get('category');
  62. $className = 'App\\Settings\\' . $category . 'Settings';
  63. if (method_exists($className, 'getValidations')) {
  64. $validations = $className::getValidations();
  65. } else {
  66. $validations = [];
  67. }
  68. $validator = Validator::make($request->all(), $validations);
  69. if ($validator->fails()) {
  70. return Redirect::to('admin/settings' . '#' . $category)->withErrors($validator)->withInput();
  71. }
  72. $settingsClass = new $className();
  73. foreach ($settingsClass->toArray() as $key => $value) {
  74. switch (gettype($value)) {
  75. case 'boolean':
  76. $settingsClass->$key = $request->has($key);
  77. break;
  78. case 'string':
  79. $settingsClass->$key = $request->input($key) ?? '';
  80. break;
  81. case 'integer':
  82. $settingsClass->$key = $request->input($key) ?? 0;
  83. break;
  84. case 'array':
  85. $settingsClass->$key = $request->input($key) ?? [];
  86. break;
  87. case 'double':
  88. $settingsClass->$key = $request->input($key) ?? 0.0;
  89. break;
  90. }
  91. }
  92. $settingsClass->save();
  93. return Redirect::to('admin/settings' . '#' . $category)->with('success', 'Settings updated successfully.');
  94. }
  95. }