import {
  Body,
  Controller,
  Delete,
  Get,
  Param,
  Patch,
  Post,
  Query,
  UseGuards,
} from '@nestjs/common';
import {
  ApiBearerAuth,
  ApiOperation,
  ApiParam,
  ApiTags,
} from '@nestjs/swagger';
import { AppPermission } from '@aechr/shared';
import { CurrentUser } from '../../common/decorators/current-user.decorator';
import { Permissions as PermissionsDecorator } from '../../common/decorators/permissions.decorator';
import { JwtAuthGuard } from '../../common/guards/jwt-auth.guard';
import type { JwtAuthUser } from '../../common/interfaces/jwt-auth-user.interface';
import { ApiJwtErrorResponses } from '../../common/swagger/api-error-responses.decorator';
import {
  ApiEnvelopeCreatedResponse,
  ApiEnvelopeOkResponse,
  ApiPaginatedEnvelopeOkResponse,
} from '../../common/swagger/api-success-responses.decorator';
import { QuestionResponseDto } from '../../common/swagger/response-models.dto';
import { CreateQuestionDto } from './dto/create-question.dto';
import { QuestionQueryDto } from './dto/question-query.dto';
import { UpdateQuestionDto } from './dto/update-question.dto';
import { QuestionsService } from './questions.service';

@ApiTags('Questions')
@ApiBearerAuth()
@UseGuards(JwtAuthGuard)
@Controller('questions')
export class QuestionsController {
  constructor(private readonly questionsService: QuestionsService) {}

  @Get()
  @PermissionsDecorator(AppPermission.QUESTIONS_READ)
  @ApiOperation({ summary: 'List question bank items' })
  @ApiPaginatedEnvelopeOkResponse(QuestionResponseDto, 'Paginated question bank list')
  @ApiJwtErrorResponses()
  list(@Query() query: QuestionQueryDto) {
    return this.questionsService.list(query);
  }

  @Post()
  @PermissionsDecorator(AppPermission.QUESTIONS_WRITE)
  @ApiOperation({ summary: 'Create question bank item' })
  @ApiEnvelopeCreatedResponse(QuestionResponseDto, 'Question created successfully')
  @ApiJwtErrorResponses({ conflict: 'Question code already exists' })
  create(@Body() body: CreateQuestionDto, @CurrentUser() user: JwtAuthUser) {
    return this.questionsService.create(body, user);
  }

  @Get(':id')
  @PermissionsDecorator(AppPermission.QUESTIONS_READ)
  @ApiOperation({ summary: 'Get question detail' })
  @ApiParam({ name: 'id', description: 'Question identifier' })
  @ApiEnvelopeOkResponse(QuestionResponseDto, 'Question detail')
  @ApiJwtErrorResponses({ notFound: 'Question was not found' })
  findOne(@Param('id') id: string) {
    return this.questionsService.findOne(id);
  }

  @Patch(':id')
  @PermissionsDecorator(AppPermission.QUESTIONS_WRITE)
  @ApiOperation({ summary: 'Update question bank item' })
  @ApiParam({ name: 'id', description: 'Question identifier' })
  @ApiEnvelopeOkResponse(QuestionResponseDto, 'Question updated successfully')
  @ApiJwtErrorResponses({
    conflict: 'Question code already exists',
    notFound: 'Question was not found',
  })
  update(
    @Param('id') id: string,
    @Body() body: UpdateQuestionDto,
    @CurrentUser() user: JwtAuthUser,
  ) {
    return this.questionsService.update(id, body, user);
  }

  @Delete(':id')
  @PermissionsDecorator(AppPermission.QUESTIONS_WRITE)
  @ApiOperation({ summary: 'Soft delete question bank item' })
  @ApiParam({ name: 'id', description: 'Question identifier' })
  @ApiEnvelopeOkResponse(QuestionResponseDto, 'Question deleted successfully')
  @ApiJwtErrorResponses({ notFound: 'Question was not found' })
  remove(@Param('id') id: string, @CurrentUser() user: JwtAuthUser) {
    return this.questionsService.remove(id, user);
  }

  @Patch(':id/restore')
  @PermissionsDecorator(AppPermission.QUESTIONS_WRITE)
  @ApiOperation({ summary: 'Restore soft-deleted question bank item' })
  @ApiParam({ name: 'id', description: 'Question identifier' })
  @ApiEnvelopeOkResponse(QuestionResponseDto, 'Question restored successfully')
  @ApiJwtErrorResponses({ notFound: 'Question was not found' })
  restore(@Param('id') id: string, @CurrentUser() user: JwtAuthUser) {
    return this.questionsService.restore(id, user);
  }
}
