mirror of
				https://github.com/anna-sara/filament_inventory
				synced 2025-10-26 20:17:14 +01:00 
			
		
		
		
	Compare commits
	
		
			2 commits
		
	
	
		
			b5844f0f48
			...
			a71a9548a3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | a71a9548a3 | ||
|  | a3f3773834 | 
					 5 changed files with 78 additions and 15 deletions
				
			
		|  | @ -219,8 +219,6 @@ class Reserve extends BasePage implements HasTable | |||
|                         TextEntry::make('desc') | ||||
|                         ->label('Description') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('acquisition_date') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('category.name') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('players') | ||||
|  | @ -229,8 +227,6 @@ class Reserve extends BasePage implements HasTable | |||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('age') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('cost') | ||||
|                         ->translateLabel(), | ||||
|                     ]) | ||||
|                     ->columns() | ||||
|                     ->hidden(fn ($record) =>  $record->type === 'literature'), | ||||
|  | @ -242,12 +238,8 @@ class Reserve extends BasePage implements HasTable | |||
|                         TextEntry::make('desc') | ||||
|                         ->label('Description') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('acquisition_date') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('category.name') | ||||
|                         ->translateLabel(), | ||||
|                         TextEntry::make('cost') | ||||
|                         ->translateLabel(), | ||||
|                     ]) | ||||
|                     ->columns() | ||||
|                     ->hidden(fn ($record) => $record->type === "game"), | ||||
|  |  | |||
|  | @ -8,6 +8,8 @@ use Filament\Widgets\StatsOverviewWidget\Card; | |||
| use App\Models\User; | ||||
| use App\Models\Item; | ||||
| use App\Models\Reserveditem; | ||||
| use Filament\Support\Enums\IconPosition; | ||||
| 
 | ||||
| 
 | ||||
| class AdminWidget extends BaseWidget | ||||
| { | ||||
|  | @ -17,10 +19,10 @@ class AdminWidget extends BaseWidget | |||
|     { | ||||
|         return [ | ||||
|             //Card::make(__('Total number of users'), User::count() ),
 | ||||
|             Card::make(__('Total number of games'), Item::where('type', 'game')->count() ), | ||||
|             Card::make(__('Total number of items'), Item::where('type', 'item')->count() ), | ||||
|             Card::make(__('Reservations at the moment'), Reserveditem::where('returned_date', null)->count() ), | ||||
|             Card::make(__('Reservations over time'), Reserveditem::withTrashed()->withTrashed()->count() ), | ||||
|             Stat::make(__('Total amount of games'), Item::where('type', 'game')->count() ), | ||||
|             Stat::make(__('Total amount of items'), Item::where('type', 'item')->count() ), | ||||
|             Stat::make(__('Reservations at the moment'), Reserveditem::where('returned_date', null)->count() ), | ||||
|             Stat::make(__('Reservations over time'), Reserveditem::withTrashed()->withTrashed()->count() ), | ||||
|         ]; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										66
									
								
								app/Filament/Widgets/PopularCategoryChart.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								app/Filament/Widgets/PopularCategoryChart.php
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,66 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace App\Filament\Widgets; | ||||
| 
 | ||||
| use Filament\Widgets\ChartWidget; | ||||
| use App\Models\Reserveditem; | ||||
| use App\Models\Category; | ||||
| 
 | ||||
| 
 | ||||
| class PopularCategoryChart extends ChartWidget | ||||
| { | ||||
|     protected static ?string $heading = 'Game reservations by category'; | ||||
|     protected static ?string $maxHeight = '275px'; | ||||
| 
 | ||||
|     protected static ?array $options = [ | ||||
|         'scales' => [ | ||||
|             'x' => [ | ||||
|                 'display' => false, | ||||
|             ], | ||||
|             'y' => [ | ||||
|                 'display' => false, | ||||
|             ], | ||||
|         ], | ||||
|     ]; | ||||
| 
 | ||||
|     protected function getData(): array | ||||
|     { | ||||
|         $categories = Category::where('type', 'game')->get(); | ||||
|         $categoryNames = []; | ||||
|          | ||||
|         foreach ($categories as $obj){ | ||||
|             $categoryNames[] = $obj->name; | ||||
|         } | ||||
| 
 | ||||
|         $items = Reserveditem::withTrashed()->with('item')->whereHas('item', function($query){ | ||||
|             return $query->where('type', 'game'); | ||||
|         })->get()->groupBy('item.category_id'); | ||||
| 
 | ||||
| 
 | ||||
|         $itemCategoriesCount = []; | ||||
| 
 | ||||
|         foreach ($items as $item){ | ||||
|             | ||||
|                 $itemCategoriesCount[] = $item->count(); | ||||
|              | ||||
|         } | ||||
|                  | ||||
|         return [ | ||||
|             'datasets' => [ | ||||
|                 [ | ||||
|                     'label' => __('Reservation Category'), | ||||
|                     'data' => $itemCategoriesCount, | ||||
|                     'backgroundColor' => ["#03045e","#0077b6","#00b4d8","#90e0ef","#caf0f8"], | ||||
|                     "hoverOffset" => 4, | ||||
|                 ], | ||||
|             ], | ||||
|             'labels' => $categoryNames, | ||||
|              | ||||
|         ]; | ||||
|     } | ||||
| 
 | ||||
|     protected function getType(): string | ||||
|     { | ||||
|         return 'pie'; | ||||
|     } | ||||
| } | ||||
|  | @ -10,6 +10,7 @@ use App\Models\Reserveditem; | |||
| class ReservationsChart extends ChartWidget | ||||
| { | ||||
|     protected static ?string $heading = "Reservations by month"; | ||||
|     protected static ?string $maxHeight = '300px'; | ||||
|      | ||||
|      | ||||
|     protected function getData(): array | ||||
|  |  | |||
							
								
								
									
										8
									
								
								lang/vendor/filament-panels/sv.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								lang/vendor/filament-panels/sv.json
									
									
									
									
										vendored
									
									
								
							|  | @ -33,8 +33,8 @@ | |||
|     "Is admin": "Admin", | ||||
|     "Password": "Lösenord", | ||||
|     "Email verified at": "Email verifierad den", | ||||
|     "Total number of games": "Totalt antal spel i lager", | ||||
|     "Total number of items": "Totalt antal saker i lager", | ||||
|     "Total amount of games": "Totalt antal spel i lager", | ||||
|     "Total amount of items": "Totalt antal saker i lager", | ||||
|     "Reservations at the moment": "Nuvarande reservationer", | ||||
|     "Reservations over time": "Alla reservationer", | ||||
|     "Phone": "Telefonnummer", | ||||
|  | @ -42,5 +42,7 @@ | |||
|     "Category literature": "Kategori litteratur", | ||||
|     "Category games": "Kategori spel", | ||||
|     "Category items": "Kategori saker", | ||||
|     "Reservations by month": "Reservationer per månad" | ||||
|     "Reservations by month": "Reservationer per månad", | ||||
|     "Amount of games in inventory": "Antal spel i lager", | ||||
|     "Amount of items in inventory": "Antal saker i lager" | ||||
| } | ||||
		Loading…
	
		Reference in a new issue