Comments (5)
Hi,
The relay ArgsBuilder or any other builder, can be combine with custom args. You must just add the args entry as you do when not using builder.
from graphqlbundle.
This is my concrete problem:
I'm trying to obtain a Foo collection resource that can be filtered by customFooArg
and customFooArg2
but React Relay throws
Uncaught Error: Relay transform error Invalid root field foos; Relay only supports root fields with zero or one argument.
foos:
type: "FooConnection"
argsBuilder: ConnectionArgs
args:
customFooArg:
description: "description of custom foo arg"
type: "String"
customFooArg2:
description: "description of custom foo arg 2"
type: "String"
import Relay from 'react-relay';
import RelayQuery from 'react-relay/lib/RelayQuery';
import RelayQueryRequest from 'react-relay/lib/RelayQueryRequest';
const query = Relay.QL`
query {
tasks(customFooArg: $customFooArg, customFooArg2: customFooArg2) {
totalCount,
edges {
node {
id
description,
customFooArg,
customFooArg2
}
cursor
}
pageInfo {
endCursor,
hasNextPage
}
}
}
`;
class FoosQueryRequest extends RelayQueryRequest {
static build({customFooArg = null, customFooArg2 = null} = {}) {
return new RelayQueryRequest(
RelayQuery.Root.create(query, {}, {
customFooArg,
customFooArg2
})
);
}
}
export default FoosQueryRequest;
from graphqlbundle.
It seems to be a relay limitation, i have try ConnectionArgs builder with one additional arg but never with more... in this issue it look like you must use an input object to bypass limitation.
#...
fields:
foos:
type: "FooConnection"
argsBuilder: ConnectionArgs
args:
customFooArgs:
description: "description of custom foo arg"
type: "CustomFooArgs"
CustomFooArgs:
type: input-object
config:
fields:
customFooArg:
description: "description of custom foo arg"
type: "String"
customFooArg2:
description: "description of custom foo arg 2"
type: "String"
from graphqlbundle.
Yeah I solve the issue with input-object type, but I have put the connection arguments inside CustomFooArgs input object to avoid the limitation
from graphqlbundle.
Yeah that a nice news :) .
from graphqlbundle.
Related Issues (20)
- Add support for `parseValue` configuration for `input-object` types
- Dynamic fields from database HOT 1
- Default enum value for argument when using annotations HOT 3
- MetadataParser will throw exception if you have Symfony PHP Configurations in your bundle HOT 4
- Types with same name differents according to schema
- Example from doc not working under Symfony 6 HOT 1
- The path "overblog_graphql_types.RootQuery._object_config.fields" should have at least 1 element(s) defined. HOT 10
- Ignoring of the name parameter of field attribute HOT 3
- Dataloader or Resolver Contexts & Parameters
- Type error introduced in 1.2.0 HOT 23
- Multiline documentation with a graphql schema leads to unnececairy indent/code block formatting HOT 1
- Multi level Input-object validation issue HOT 1
- Automatic type resolver for annotations/attributes
- ArgumentTransfomer should only validate arguments of type input
- Default field value for Input Object
- Annotations should be deprecated HOT 3
- Arguments order shouldn't matter
- Add ability to set HTTP status code and set own headers
- Help: Unclear how to use validation "link" with mutation/input objects HOT 2
- Validation is called on optional fields that are not passed
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from graphqlbundle.