Неизвестный аргумент "" on field "" типа Mutation с приложением React Native с использованием клиента Apollo и сервера Apollo - PullRequest
0 голосов
/ 14 февраля 2019
const Profile = t.struct({
 name: t.String,
 city: t.String,
 about: t.String,
});

const UPDATE_USER = gql`
 mutation UpdateAccountForm(
   $id: ID!
   $name: String
   $about: String
   $city: String
 ) {
   UpdateUser(id: $id, name: $name, about: $about, city: $city) {
     id
   }
 }
`;

export default class UpdateAccountForm extends React.Component {
 state = {
   user: {
     name: '',
     about: '',
     city: '',
   },
 };
 render() {
   const { user } = this.state;
   return (
     <Mutation mutation={UPDATE_USER}>
       {(UpdateUser, { data }) => (
         <View style={styles.container}>
           <Image
             source={require('../Images/logoBlue.jpg')}
             style={{ width: 120, height: 120 }}
           />
           <Form
             type={Profile}
             value={user}
             options={options}
             onChange={this.onChange}
           />
           <Button
             title="Submit"
             type="clear"
             titleStyle={{ color: '#4873a6' }}
             onPress={() => this._handleSaveAccount(UpdateUser)}
             containerStyle={{ marginTop: 20 }}
           />
         </View>
       )}
     </Mutation>
   );
 }

  componentDidMount = () => {
   client
     .query({
        query: gql`
         query getUser($id: ID!) {
          User(id: $id) {
              name
              city
              about
           }
          }
       `,
       variables: { id: this.props.loggedInUserId },
     })   

  _handleSaveAccount = async UpdateUser => {
   const { name, about, city } = this.state.user;
   const id = this.props.loggedInUserId;
   const { goToBookshelf } = this.props;

   await UpdateUser({
     variables: {
       id,
       name,
       about,
       city,
     },
   }).then(() => {
     goToBookshelf(id);
   });
 };
}

Может кто-нибудь помочь нам определить, в чем здесь проблема?

Кажется, он работает для некоторых мутаций и запросов, а иногда выдает непредсказуемые ошибки, подобные этой.Мы используем ответные expo и клиент apollo для внешнего интерфейса и graphql, клиент apollo и neo4j на задней панели.

Схема

type User {
  id: ID!
  uid: ID!
  name: String!
  username: String!
  email: String!
  about: String
  city: String
}

Ответы [ 2 ]

0 голосов
/ 16 мая 2019

Вы забыли data:{}

const UPDATE_USER = gql`
 mutation UpdateAccountForm(
   data:{$id: ID!, $name: String}     
 ) {
   UpdateUser(id: $id, name: $name) {
     id
   }
 }
`;

Дважды проверьте, можете ли вы отправить ID, потому что иногда он создается автоматически!

Удачи!

0 голосов
/ 14 февраля 2019

Единственное, что я вижу в проблеме - это разделитель, называемый запятой ","

const UPDATE_USER = gql`
     mutation UpdateAccountForm($id: ID!, $name: String,
                             $about: String,$city: String ) {
          UpdateUser(id: $id, name: $name, about: $about, city: $city) {
             id
          }
     }`;

. Или, пожалуйста, проверьте тип переменной мутации, передаваемый формой в мутации.

...