GraphqlとReactフロントエンドを使用して、djangoでグラフェンを使用しています。
ミューテーションの作成を機能させることはできますが、編集のミューテーションは機能しません。 $ 変数のないクエリでも、graphiQL で機能します。
React の gql const は次のとおりです。
export const EDIT_PERSON = gql`
mutation personEdit($id: id, $input: PersonInputType!) {
personEdit(id: id, input: $input) {
person {
id
}
}
}
`;
id はハンドラーから設定され、フォームの送信関数は次のようになります。
<form
autoComplete="off"
onSubmit={e => {
e.preventDefault();
editPerson({
variables: {
id: id,
input: {
firstName: firstName,
lastName: lastName,
address: address
}
}
});
}}
>
django での私の PersonEdit ミューテーションは次のようになります。
class PersonEdit(Mutation):
class Arguments:
id = ID(required=True)
input = PersonEditInputType(required=True)
person = Field(PersonType)
@classmethod
def mutate(cls, root, info, **data):
serializer = PersonSerializer(data=data.get('input'))
serializer.is_valid(raise_exception=True)
person = Person.objects.get(id=data.get('id'))
print("PERSON", serializer.data)
person.first_name = serializer.data['first_name']
person.last_name = serializer.data['last_name']
person.address = serializer.data['address']
return PersonEdit(person=person.save())
編集がうまくいかないのはなぜですか?