0

投稿を作成し、投稿リストの前に追加する Relay ミューテーションがあります。楽観的な更新は、ミューテーションが GraphQL サーバーに送信される前に、投稿のタイトルと URL をリストの先頭に追加します。私の問題は、突然変異が失敗するか完了できない場合、その楽観的な更新が後でリストから自動的に削除されることです。投稿を保存できないことを示す何らかのメッセージをユーザーに表示できるように、失敗したミューテーションをキャッチして処理する方法はありますか?

私のリレーの突然変異:

import Relay from 'react-relay';

class CreatePostMutation extends Relay.Mutation {
    getMutation () {
        return Relay.QL`
            mutation {
                createPost
            }
        `
    }

    getVariables() {
        return {
            title: this.props.title,
            url: this.props.url
        }
    }

    getFatQuery() {
        return Relay.QL`
            fragment on CreatePostPayload {
                postEdge,
                store {
                    id
                }
            }
        `;
    }

    getConfigs() {
        return [{
            type: 'RANGE_ADD',
            parentName: 'store',
            parentID: this.props.store.id,
            connectionName: 'allPosts',
            edgeName: 'postEdge',
            rangeBehaviors: {
                '': 'prepend'
            }
        }]
    }

    getOptimisticResponse() {
        return {
            postEdge: {
                node: {
                    title: this.props.title,
                    url: this.props.url
                }
            }
        }
    }
}

export default CreatePostMutation;

私のPostForm Reactコンポーネント:

import React from 'react';
import Relay from 'react-relay';

import CreatePostMutation from '../../mutations/create_post';

class PostForm extends React.Component {
    handleSubmit = (e) => {
        e.preventDefault();

        let {relay, store} = this.props;
        let {title, url}   = this.refs;

        relay.commitUpdate(
            new CreatePostMutation({
                title: title.value,
                url: url.value,
                store
            })
        );

        // clear values
        title.value = '';
        url.value   = '';
    }

    render () {
        return (
            <div>
                <form onSubmit={this.handleSubmit}>
                    <input name="title" placeholder="Title" ref="title" />
                    <input name="url" placeholder="URL" ref="url" />
                    <input type="submit" />
                </form>
            </div>
        )
    }
}

export default PostForm;
4

1 に答える 1

2

PostFormコンポーネントのhandleSubmit関数で、呼び出し中のミューテーションの失敗を処理するコールバックを提供しますcommitUpdate

const onFailure = (transaction) => {
    // Notify user that the post could not be added.
};
const onSuccess = () => {
    console.log('Post added.')
};
relay.commitUpdate(
    new CreatePostMutation({
        title: title.value,
        url: url.value,
        store
    }),
    {onFailure, onSuccess}
);

Relay Mutation API documentationで例を見つけることができます。

上記の方法を使用すると、システム エラー (例外がスローされるなど) が発生することに注意してください。ユーザー入力の問題でエラーをスローした場合、ユーザー エラー (検証エラーなど) を 1 つだけ受け取ることもできます。すべてのユーザー エラーをまとめて受信したい場合は、次の優れた記事で提案されているアプローチに従うことを検討してください: Validation and User Errors in GraphQL Mutations

于 2016-07-31T18:09:26.897 に答える