diff --git a/src/app/Http/Controllers/AdminController.php b/src/app/Http/Controllers/AdminController.php new file mode 100644 index 0000000..d7c783b --- /dev/null +++ b/src/app/Http/Controllers/AdminController.php @@ -0,0 +1,52 @@ + 'target_margin', 'name' => 'Target Margin (%)', 'type' => 'integer', 'default' => 20, 'description' => 'Target gross margin percentage for alerts.'], + ['key' => 'low_stock_threshold', 'name' => 'Low Stock Warning', 'type' => 'integer', 'default' => 50, 'description' => 'Quantity at which a product is considered low stock.'], + ['key' => 'default_date_range', 'name' => 'Default Date Filter', 'type' => 'string', 'default' => 'YTD', 'description' => 'Default date range on load (e.g. YTD, All).'], + ]; + } else if ($dashboard === 'sales') { + $schema = [ + ['key' => 'monthly_target', 'name' => 'Monthly Sales Target', 'type' => 'integer', 'default' => 100000, 'description' => 'Overall monthly sales target.'], + ]; + } else { + abort(404); + } + + // Fetch current settings from DB + $settings = Setting::where('dashboard', $dashboard)->get()->keyBy('key'); + + return view('admin.settings', compact('dashboard', 'schema', 'settings')); + } + + public function updateSettings(Request $request, $dashboard) + { + $settingsData = $request->except('_token'); + + foreach ($settingsData as $key => $value) { + Setting::updateOrCreate( + ['dashboard' => $dashboard, 'key' => $key], + ['value' => $value] + ); + } + + return redirect()->back()->with('success', ucfirst($dashboard) . ' settings saved successfully!'); + } +} diff --git a/src/app/Models/Setting.php b/src/app/Models/Setting.php new file mode 100644 index 0000000..910e4fc --- /dev/null +++ b/src/app/Models/Setting.php @@ -0,0 +1,39 @@ +where('key', $key)->first(); + if (!$setting) { + return $default; + } + + switch ($setting->type) { + case 'boolean': + return filter_var($setting->value, FILTER_VALIDATE_BOOLEAN); + case 'integer': + return (int) $setting->value; + case 'json': + return json_decode($setting->value, true); + default: + return $setting->value; + } + } +} diff --git a/src/database/migrations/2026_03_06_025530_create_settings_table.php b/src/database/migrations/2026_03_06_025530_create_settings_table.php new file mode 100644 index 0000000..7f8da8c --- /dev/null +++ b/src/database/migrations/2026_03_06_025530_create_settings_table.php @@ -0,0 +1,35 @@ +id(); + $table->string('dashboard')->index(); // e.g., 'procurement', 'sales', 'global' + $table->string('key'); + $table->text('value')->nullable(); + $table->string('type')->default('string'); // string, boolean, integer, json + $table->string('name')->nullable(); // Human-readable name + $table->text('description')->nullable(); + $table->timestamps(); + + $table->unique(['dashboard', 'key']); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('settings'); + } +}; diff --git a/src/resources/views/admin/index.blade.php b/src/resources/views/admin/index.blade.php new file mode 100644 index 0000000..84a76fd --- /dev/null +++ b/src/resources/views/admin/index.blade.php @@ -0,0 +1,28 @@ +@extends('admin.layout') + +@section('content') +
Manage dashboard settings and globally defined parameters.
+Configure thresholds, margins, and default variables for the procurement module.
+ + + +Configure revenue targets and metric parameters for the upcoming sales dashboard.
+ + +System Configuration
+Adjust constants and parameters specific to this dashboard.
+