11 Commits

Author SHA1 Message Date
dhanabalan
7d3ae71b20 Created User table resources 2025-04-20 17:15:12 +05:30
dhanabalan
8d99ebc9d7 Alignment changed on Item Code 2025-04-20 17:13:50 +05:30
dhanabalan
72060276c5 Removed unnecessary 'ExcelImport' use 2025-04-20 17:12:28 +05:30
dhanabalan
79b8ef3318 Updated navigationSort order from 6 to 5 2025-04-20 17:11:09 +05:30
dhanabalan
5da1683201 Updated navigationSort order from 5 to 6 2025-04-20 17:10:52 +05:30
dhanabalan
e7cecdf049 Added SoftDeletes 2025-04-20 17:09:13 +05:30
dhanabalan
62397a1c5d Added multiple super admin user and reduced random user creation upto 5 2025-04-20 17:08:14 +05:30
dhanabalan
eb72a0f564 Added deleted_at column using softDeletes() 2025-04-20 17:03:51 +05:30
dhanabalan
0e2a6cfb2d Removed serial_number / item_id - serial_number unique constrain and Added combined unique constraints using plant_id and item_id 2025-04-20 17:03:00 +05:30
dhanabalan
3d50c67c6d Added combined unique constraints using plant_id and item_id 2025-04-20 17:01:33 +05:30
dhanabalan
283761003b Added combined unique constraints using plant_id and serial_number 2025-04-20 17:00:36 +05:30
15 changed files with 233 additions and 11 deletions

View File

@@ -16,12 +16,12 @@ class StickerMasterImporter extends Importer
return [
ImportColumn::make('item')
->requiredMapping()
->exampleHeader('Item Code')
->label('Item Code')
->relationship(resolveUsing: 'code')
->exampleHeader('Item Code')
->rules(['required']),
ImportColumn::make('plant')
ImportColumn::make('plant')
->requiredMapping()
->exampleHeader('Plant Name')
->label('Plant Name')

View File

@@ -3,7 +3,6 @@
namespace App\Filament\Resources;
use App\Filament\Resources\InvoiceValidationResource\Pages;
use App\Imports\ExcelImport;
use App\Models\InvoiceValidation;
use App\Models\Plant;
use App\Models\StickerMaster;

View File

@@ -29,7 +29,7 @@ class ItemResource extends Resource
protected static ?string $navigationGroup = 'Master Entries';
protected static ?int $navigationSort = 5;
protected static ?int $navigationSort = 6;
public static function form(Form $form): Form
{

View File

@@ -26,7 +26,7 @@ class LineResource extends Resource
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
protected static ?string $navigationGroup = 'Master Entries';
protected static ?int $navigationSort = 6;
protected static ?int $navigationSort = 5;
public static function form(Form $form): Form
{

View File

@@ -0,0 +1,120 @@
<?php
namespace App\Filament\Resources;
use App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource\RelationManagers;
use App\Models\User;
use Filament\Forms;
use Filament\Forms\Form;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class UserResource extends Resource
{
protected static ?string $model = User::class;
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
protected static ?string $navigationGroup = 'User Management';
public static function form(Form $form): Form
{
return $form
->schema([
Forms\Components\TextInput::make('name')
->required()
->reactive()
->afterStateUpdated(function ($state, callable $set, callable $get) {
$set('email', $state . '@cripumps.com');
})
->maxLength(255),
Forms\Components\TextInput::make('email')
// ->email()
->required()
->readOnly()
->reactive()
//->prefix(fn ($get) => $get('name') ?? null)
// ->suffix('@cripumps.com')
->maxLength(255),
Forms\Components\DateTimePicker::make('email_verified_at'),
Forms\Components\TextInput::make('password')
->password()
->revealable()
->required()
->maxLength(255),
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id')
->label('ID')
->numeric()
->sortable(),
Tables\Columns\TextColumn::make('name')
->searchable(),
Tables\Columns\TextColumn::make('email')
->searchable(),
Tables\Columns\TextColumn::make('email_verified_at')
->dateTime()
->sortable(),
Tables\Columns\TextColumn::make('created_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
Tables\Columns\TextColumn::make('updated_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
Tables\Columns\TextColumn::make('deleted_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
])
->filters([
Tables\Filters\TrashedFilter::make(),
])
->actions([
Tables\Actions\ViewAction::make(),
Tables\Actions\EditAction::make(),
])
->bulkActions([
Tables\Actions\BulkActionGroup::make([
Tables\Actions\DeleteBulkAction::make(),
Tables\Actions\ForceDeleteBulkAction::make(),
Tables\Actions\RestoreBulkAction::make(),
]),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
'index' => Pages\ListUsers::route('/'),
'create' => Pages\CreateUser::route('/create'),
'view' => Pages\ViewUser::route('/{record}'),
'edit' => Pages\EditUser::route('/{record}/edit'),
];
}
public static function getEloquentQuery(): Builder
{
return parent::getEloquentQuery()
->withoutGlobalScopes([
SoftDeletingScope::class,
]);
}
}

View File

@@ -0,0 +1,12 @@
<?php
namespace App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource;
use Filament\Actions;
use Filament\Resources\Pages\CreateRecord;
class CreateUser extends CreateRecord
{
protected static string $resource = UserResource::class;
}

View File

@@ -0,0 +1,22 @@
<?php
namespace App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource;
use Filament\Actions;
use Filament\Resources\Pages\EditRecord;
class EditUser extends EditRecord
{
protected static string $resource = UserResource::class;
protected function getHeaderActions(): array
{
return [
Actions\ViewAction::make(),
Actions\DeleteAction::make(),
Actions\ForceDeleteAction::make(),
Actions\RestoreAction::make(),
];
}
}

View File

@@ -0,0 +1,19 @@
<?php
namespace App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource;
use Filament\Actions;
use Filament\Resources\Pages\ListRecords;
class ListUsers extends ListRecords
{
protected static string $resource = UserResource::class;
protected function getHeaderActions(): array
{
return [
Actions\CreateAction::make(),
];
}
}

View File

@@ -0,0 +1,19 @@
<?php
namespace App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource;
use Filament\Actions;
use Filament\Resources\Pages\ViewRecord;
class ViewUser extends ViewRecord
{
protected static string $resource = UserResource::class;
protected function getHeaderActions(): array
{
return [
Actions\EditAction::make(),
];
}
}

View File

@@ -4,6 +4,7 @@ namespace App\Models;
// use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Spatie\Permission\Traits\HasRoles;
@@ -11,7 +12,7 @@ use Spatie\Permission\Traits\HasRoles;
class User extends Authenticatable
{
/** @use HasFactory<\Database\Factories\UserFactory> */
use HasFactory, HasRoles, Notifiable;
use HasFactory, HasRoles, Notifiable, SoftDeletes; //
/**
* The attributes that are mass assignable.

View File

@@ -19,6 +19,7 @@ return new class extends Migration
$table->string('password');
$table->rememberToken();
$table->timestamps();
$table->softDeletes();
});
Schema::create('password_reset_tokens', function (Blueprint $table) {

View File

@@ -20,13 +20,13 @@ return new class extends Migration
plant_id BIGINT NOT NULL,
item_id BIGINT NOT NULL,
serial_number TEXT NOT NULL UNIQUE,
serial_number TEXT NOT NULL,
created_at TIMESTAMP NOT NULL DEFAULT NOW(),
updated_at TIMESTAMP NOT NULL DEFAULT NOW(),
deleted_at TIMESTAMP,
UNIQUE (item_id, serial_number),
UNIQUE (plant_id, serial_number),
FOREIGN KEY (item_id) REFERENCES items (id),
FOREIGN KEY (line_id) REFERENCES lines (id),
FOREIGN KEY (shift_id) REFERENCES shifts (id),

View File

@@ -51,6 +51,7 @@ return new class extends Migration
updated_at TIMESTAMP NOT NULL DEFAULT NOW(),
deleted_at TIMESTAMP,
UNIQUE (plant_id, item_id),
FOREIGN KEY (item_id) REFERENCES items (id),
FOREIGN KEY (plant_id) REFERENCES plants (id)
);

View File

@@ -19,7 +19,7 @@ return new class extends Migration
plant_id BIGINT NOT NULL,
invoice_number TEXT NOT NULL,
serial_number TEXT UNIQUE,
serial_number TEXT DEFAULT NULL,
motor_scanned_status TEXT DEFAULT NULL,
pump_scanned_status TEXT DEFAULT NULL,
@@ -42,6 +42,7 @@ return new class extends Migration
updated_at TIMESTAMP NOT NULL DEFAULT NOW(),
deleted_at TIMESTAMP,
UNIQUE (plant_id, serial_number),
FOREIGN KEY (sticker_master_id) REFERENCES sticker_masters (id),
FOREIGN KEY (plant_id) REFERENCES plants (id)
);

View File

@@ -17,9 +17,36 @@ class UserSeeder extends Seeder
'email' => 'admin@cripumps.com',
'password' => bcrypt('admin'),
]);
$user1->assignRole('Super Admin');
User::factory()->count(10)->create();
$user2 = User::create([
'name' => 'Jothi',
'email' => 'jothi@cripumps.com',
'password' => bcrypt('jothi@123'),
]);
$user2->assignRole('Super Admin');
$user3 = User::create([
'name' => 'Dhana',
'email' => 'dhana@cripumps.com',
'password' => bcrypt('dhana@123'),
]);
$user3->assignRole('Super Admin');
$user4 = User::create([
'name' => 'Ranjith',
'email' => 'ranjith@cripumps.com',
'password' => bcrypt('ranjith@123'),
]);
$user4->assignRole('Super Admin');
$user5 = User::create([
'name' => 'Srimathi',
'email' => 'srimathi@cripumps.com',
'password' => bcrypt('srimathi@123'),
]);
$user5->assignRole('Super Admin');
User::factory()->count(5)->create();
}
}