执行Apollo突变之前的映射变量

时间:2018-12-16 08:54:07

标签: reactjs graphql apollo react-apollo

我一直遵循this tutorial来使React应用程序与Apollo一起运行。

现在我正在进行突变,我已经成功完成了这一步,但我正在尝试执行更复杂的突变。

因此,此突变中期望的字段之一是关联,期望 connect 数据集,该数据集必须类似于:

tags: {
  connect: [{
   id: "cjoo9e0eq004d0824nibmtzl2"
  },
  {
   id: "cjoopece2000a0899n8jsjkr4"
  },
  {
   id: "cjozmqfal00040878t7huvb2s"
  },
  {
   id: "cjozmsquv000l0878y7t2zccm"
  }],
},

对于此标签字段,在前端,我将显示一个选择多选,因此该值将是一个ID数组:[“ cjoo9e0eq004d0824nibmtzl2”,“ cjoopece2000a0899n8jsjkr4” ...]。

由于该突变期望该字段是具有id的对象的数组,因此我试图以某种方式映射该字符串以将其转换为期望的格式,但是我没有任何运气。我不知道在执行突变之前在哪里可以转换该变量。

似乎要解释一个棘手的问题,我希望解释足够清楚。

任何帮助将不胜感激!

编辑以添加一些代码:

const CREATE_VIDEO_MUTATION = gql`
  mutation CreateVideoMutation($title: String!, $tags: [TagWhereUniqueInput!]) {
    createVideo(
      data: {
        title: $title, 
        tags: {
          connect: $tags
        }
      }
    ) {
      id
      title
    }
  }
`

class CreateVideo extends Component {
  state = {
    title: '',
    tags: [],
  }

  render() {
    const { title, tags } = this.state;
    return (
        .....

      <select multiple 
        className="mb2" 
        value={tags}
        onChange={e => {
          this.setState({ tags: [...e.target.options]
            .filter(({selected}) => selected)
            .map(({value}) => value) })
        }}>
        {tagsToRender.map(tag => {
          return (
            <option key={tag.id} value={tag.id}>
              {tag.name}
            </option>
          )
        })}
      </select>

      <Mutation 
        mutation={CREATE_VIDEO_MUTATION} 
        variables={{ title, tags }}
        onCompleted={() => this.props.history.push('/')}>
        {createVideoMutation => <button onClick={createVideoMutation}>Submit</button>}
      </Mutation>

1 个答案:

答案 0 :(得分:1)

下面应该这样做。

const _tags = tags.map(tag => ({id}))

<Mutation 
    mutation={CREATE_VIDEO_MUTATION} 
    variables={{ title, tags: _tags }}
    onCompleted={() => this.props.history.push('/')}>
    {createVideoMutation => <button onClick={createVideoMutation}>Submit</button>}
  </Mutation>