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
}