0

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())

編集がうまくいかないのはなぜですか?

4

1 に答える 1