import {
  Controller, Get, Post, Patch, Delete,
  Body, Param, Query, UseGuards, ParseUUIDPipe,
} from '@nestjs/common';
import { TransportServiceService } from './transport-service.service';
import { CreateTransportServiceDto, UpdateTransportServiceDto } from './dto';
import { JwtAuthGuard } from '../../auth/guards/jwt-auth.guard';
import { PermissionGuard } from '../../auth/guards/permission.guard';
import { Permissions } from '../../auth/decorators/permissions.decorator';
import { AccessLevel, ModuleName } from '../../entities/role-permission.entity';
import { paginatedResponse, successResponse } from '../../common/responses/api-response';
import { PaginationDto } from '../../common/dto/pagination.dto';
import { Lookup } from '../../common/decorators/lookup.decorator';

@Controller('transport-services')
@UseGuards(JwtAuthGuard, PermissionGuard)
export class TransportServiceController {
  constructor(private readonly service: TransportServiceService) {}

  @Get()
  @Permissions({ module: ModuleName.TRANSPORTATION, accessLevel: AccessLevel.VIEW })
  async findAll(
    @Query() query: PaginationDto,
    @Query('destination_id') destinationId?: string,
    @Query('category') category?: string,
  ) {
    const { items, meta } = await this.service.findAll(query, { destinationId, category });
    return paginatedResponse(items, meta, 'Transport services fetched successfully');
  }

  @Get('lookup')
  @Lookup()
  async lookup() {
    const items = await this.service.findAllForLookup();
    return successResponse(items, 'Transport services lookup');
  }

  @Get(':id')
  @Permissions({ module: ModuleName.TRANSPORTATION, accessLevel: AccessLevel.VIEW })
  async findById(@Param('id', ParseUUIDPipe) id: string) {
    const data = await this.service.findById(id);
    return successResponse(data, 'Transport service fetched successfully');
  }

  @Post()
  @Permissions({ module: ModuleName.TRANSPORTATION, accessLevel: AccessLevel.CREATE })
  async create(@Body() dto: CreateTransportServiceDto) {
    const result = await this.service.create(dto);
    return successResponse(result, result.message);
  }

  @Patch(':id')
  @Permissions({ module: ModuleName.TRANSPORTATION, accessLevel: AccessLevel.EDIT })
  async update(@Param('id', ParseUUIDPipe) id: string, @Body() dto: UpdateTransportServiceDto) {
    const result = await this.service.update(id, dto);
    return successResponse(result, result.message);
  }

  @Delete(':id')
  @Permissions({ module: ModuleName.TRANSPORTATION, accessLevel: AccessLevel.DELETE })
  async remove(@Param('id', ParseUUIDPipe) id: string) {
    const result = await this.service.remove(id);
    return successResponse(result, result.message);
  }
}
