demarches-normaliennes/app/graphql/mutations/groupe_instructeur_creer.rb

62 lines
2.7 KiB
Ruby
Raw Normal View History

module Mutations
class GroupeInstructeurCreer < Mutations::BaseMutation
class GroupeInstructeurAttributes < Types::BaseInputObject
description "Attributs pour lajout d'un groupe instructeur."
argument :label, String, "Libelle du groupe instructeur.", required: true
argument :closed, Boolean, "Létat du groupe instructeur.", required: false, default_value: false
argument :instructeurs, [Types::ProfileInput], "Instructeurs à ajouter.", required: false, default_value: []
end
description "Crée un groupe instructeur."
argument :demarche, Types::DemarcheDescriptorType::FindDemarcheInput, "Demarche ID ou numéro.", required: true
argument :groupe_instructeur, GroupeInstructeurAttributes, "Groupes instructeur à ajouter.", required: true
field :groupe_instructeur, Types::GroupeInstructeurType, null: true
field :errors, [Types::ValidationErrorType], null: true
field :warnings, [Types::WarningMessageType], null: true
def resolve(demarche:, groupe_instructeur:)
demarche_number = demarche.number.presence || ApplicationRecord.id_from_typed_id(demarche.id)
procedure = current_administrateur.procedures.find(demarche_number)
ids, emails = partition_instructeurs_by(groupe_instructeur.instructeurs)
groupe_instructeur = procedure
.groupe_instructeurs
.build(label: groupe_instructeur.label, closed: groupe_instructeur.closed, instructeurs: [current_administrateur.instructeur].compact)
if groupe_instructeur.save
2023-05-11 15:15:25 +02:00
# ugly hack to keep retro compatibility
# do not judge
if !ENV['OLD_GROUPE_INSTRUCTEURS_CREATE_API_PROCEDURE_ID'].nil? && demarche_number.in?(ENV['OLD_GROUPE_INSTRUCTEURS_CREATE_API_PROCEDURE_ID']&.split(',')&.map(&:to_i))
stable_id = procedure.groupe_instructeurs.first.routing_rule.left.stable_id
tdc = procedure.published_revision.types_de_champ.find_by(stable_id: stable_ids)
tdc.update(options: tdc.options['drop_down_options'].push(groupe_instructeur.label))
groupe_instructeur.update(routing_rule: ds_eq(champ_value(stable_id), constant(groupe_instruteur.label)))
end
result = { groupe_instructeur: }
if emails.present? || ids.present?
_, invalid_emails = groupe_instructeur.add_instructeurs(ids:, emails:)
groupe_instructeur.reload
if invalid_emails.present?
warning = I18n.t('administrateurs.groupe_instructeurs.add_instructeur.wrong_address',
count: invalid_emails.size,
emails: invalid_emails.join(', '))
result[:warnings] = [warning]
end
end
result
else
{ errors: groupe_instructeur.errors.full_messages }
end
end
end
end