# frozen_string_literal: true module RepositoryColumns class StatusColumnsController < BaseColumnsController include InputSanitizeHelper before_action :load_column, only: %i(update destroy) before_action :check_create_permissions, only: :create before_action :check_manage_permissions, only: %i(update destroy) def create service = RepositoryColumns::CreateColumnService .call(user: current_user, repository: @repository, team: current_team, column_type: Extends::REPOSITORY_DATA_TYPES[:RepositoryStatusValue], params: repository_column_params) if service.succeed? render json: service.column, status: :created, creating: true else render json: service.errors, status: :unprocessable_entity end end def update service = RepositoryColumns::UpdateColumnService .call(user: current_user, team: current_team, column: @repository_column, params: update_repository_column_params) if service.succeed? render json: service.column, status: :ok, editing: true else render json: service.errors, status: :unprocessable_entity end end def destroy service = RepositoryColumns::DeleteColumnService .call(user: current_user, team: current_team, column: @repository_column) if service.succeed? render json: {}, status: :ok else render json: service.errors, status: :unprocessable_entity end end private def repository_column_params params.require(:repository_column).permit(:name, repository_status_items_attributes: %i(status icon)) end def update_repository_column_params params.require(:repository_column).permit(:name, repository_status_items_attributes: %i(id status icon _destroy)) end end end