Reactjs 具有多个值的字段的解析器的Drupal GraphQL逻辑

Reactjs 具有多个值的字段的解析器的Drupal GraphQL逻辑,reactjs,graphql,drupal-8,react-apollo,Reactjs,Graphql,Drupal 8,React Apollo,我的第一个Drupal无头项目是GraphQL,我正在与解析器背后的逻辑作斗争 有一个内容类型项目,其字段字段项目描述为。该字段可以存储多个值 这是我的模式的一部分: type Project { id: Int! project_title: String! project_description: [ProjectDescription] } type ProjectDescription { value: String } 这就是相应解析器的一部分的外观: $r

我的第一个Drupal无头项目是GraphQL,我正在与解析器背后的逻辑作斗争

有一个内容类型项目,其字段字段项目描述为。该字段可以存储多个值

这是我的模式的一部分:

type Project {
  id: Int!
  project_title: String!
  project_description: [ProjectDescription]
}

type ProjectDescription {
  value: String
}
这就是相应解析器的一部分的外观:

    $registry->addFieldResolver('ProjectDescription', 'value',
      $builder->produce('property_path')
        ->map('type', $builder->fromValue('entity:node'))
        ->map('value', $builder->fromParent())
        ->map('path', $builder->fromValue('field_project_project_desc.value'))
    );
但据我所知,必须有另一个类似的解析器

$registry->addFieldResolver'Project'、'Project_description'


我不知道这个解析器应该是什么样子。

好的,我自己解决了这个问题。答案其实很简单

您不需要第二个解析器。只需一个带有附加PHP函数的解析器,即可将数组展平为字符串。这就是代码现在的样子

模式:

type Project {
  id: Int!
  project_title: String!
  project_description: [String]
}
和解析器:

$registry->addFieldResolver('Project', 'project_description',
  $builder->compose(
    $builder->produce('property_path')
      ->map('type', $builder->fromValue('entity:node'))
      ->map('value', $builder->fromParent())
      ->map('path', $builder->fromValue('field_project_project_desc')),
    $builder->callback(function ($entity) {
      $list = [];
      foreach($entity as $item){
        array_push($list, $item['value']);
      }
      return $list;
    })
  )
);
我希望我能在这方面帮助别人