通过 GRAPHQL 订阅传递数据仅在其中一个参数上给出 null

IT技术 reactjs graphql subscription graphql-js
2021-05-23 01:58:31

我有以下 GRAPHQL 订阅:

Schema.graphql
    type Subscription {
      booking: SubscriptionData
    }

    type SubscriptionData {
      booking: Booking!
      action: String
    }

这是解析器订阅文件

Resolver/Subscription.js
const Subscription = {
  booking: {
    subscribe(parent, args, { pubsub }, info) {
      return pubsub.asyncIterator("booking");
    }
  }
};

export default Subscription;

然后我在有问题的 Mutation 上有以下代码

pubsub.publish("booking", { booking: { booking }, action: "test" });

我在前端有以下订阅文件(React)

const getAllBookings = gql`
  query {
    bookings {
      time
      durationMin
      payed
      selected
      activity {
        name
      }
    }
  }
`;

const getAllBookingsInitial = {
  query: gql`
    query {
      bookings {
        time
        durationMin
        payed
        selected
        activity {
          name
        }
      }
    }
  `
};

class AllBookings extends Component {
  state = { allBookings: [] }

  componentWillMount() {
    console.log('componentWillMount inside AllBookings.js')
    client.query(getAllBookingsInitial).then(res => this.setState({ allBookings: res.data.bookings })).catch(err => console.log("an error occurred: ", err));
  }

  componentDidMount() {
    console.log(this.props.getAllBookingsQuery)
    this.createBookingsSubscription = this.props.getAllBookingsQuery.subscribeToMore(
      {
        document: gql`
          subscription {
            booking {
              booking { 
                time
                durationMin
                payed
                selected
                activity {
                  name
                   }
              }
              action
            }
          }
        `,
        updateQuery: async (prevState, { subscriptionData }) => {
          console.log('subscriptionData', subscriptionData)
          const newBooking = subscriptionData.data.booking.booking;
          const newState = [...this.state.allBookings, newBooking]
          this.setState((prevState) => ({ allBookings: [...prevState.allBookings, newBooking] }))
          this.props.setAllBookings(newState);
        }
      },
      err => console.error(err)
    );
  }
  render() {
    return null;
  }
}

export default graphql(getAllBookings, { name: "getAllBookingsQuery" })(
  AllBookings
);

我得到以下回应:

data: {
booking: {booking: {...} action: null}}

我知道我可能以某种方式错误地设置了订阅,但我没有看到问题。

1个回答

根据您的架构,所需的data返回应如下所示:

{
  "booking": {
    "booking": {
      ...
    },
    "action": "test"
  }
}

第一个booking是 上的字段Subscription,而第二个预订是 SubscriptionData 上的字段。您传递给的对象publish应该具有相同的形状(即它应该始终包含根级订阅字段)。

pubsub.publish('booking', {
  booking: {
    booking,
    action: 'test',
  },
})