platform/graphql_schema/lib/src/argument.dart

53 lines
1.8 KiB
Dart
Raw Normal View History

2018-08-02 13:31:54 +00:00
part of graphql_schema.src.schema;
2018-08-05 01:52:15 +00:00
/// An input to a GraphQL field. This is analogous to a function parameter in Dart.
2018-08-04 19:18:53 +00:00
class GraphQLFieldInput<Value, Serialized> {
2018-08-05 01:52:15 +00:00
/// The name of this field.
2018-08-02 13:31:54 +00:00
final String name;
2018-08-05 01:52:15 +00:00
/// The type that input values must conform to.
2018-08-02 13:31:54 +00:00
final GraphQLType<Value, Serialized> type;
2018-08-05 01:52:15 +00:00
/// An optional default value for this field.
2018-08-02 13:31:54 +00:00
final Value defaultValue;
2018-08-05 01:52:15 +00:00
/// An optional description for this field.
///
/// This is useful when documenting your API for consumers like GraphiQL.
2018-08-03 17:45:40 +00:00
final String description;
2018-08-02 13:50:31 +00:00
2018-08-04 19:18:53 +00:00
/// If [defaultValue] is `null`, and `null` is a valid value for this parameter, set this to `true`.
2018-08-02 13:50:31 +00:00
final bool defaultsToNull;
2018-08-04 19:18:53 +00:00
static bool _isInputTypeOrScalar(GraphQLType type) {
if (type is GraphQLInputObjectType) {
return true;
} else if (type is GraphQLUnionType) {
return type.possibleTypes.every(_isInputTypeOrScalar);
} else if (type is GraphQLObjectType) {
return false;
} else if (type is GraphQLNonNullableType) {
return _isInputTypeOrScalar(type.ofType);
} else if (type is GraphQLListType) {
return _isInputTypeOrScalar(type.ofType);
} else {
return true;
}
}
GraphQLFieldInput(this.name, this.type,
{this.defaultValue, this.defaultsToNull: false, this.description}) {
assert(_isInputTypeOrScalar(type),
'All inputs to a GraphQL field must either be scalar types, or explicitly marked as INPUT_OBJECT. Call `GraphQLObjectType.asInputObject()` on any object types you are passing as inputs to a field.');
}
@override
bool operator ==(other) =>
other is GraphQLFieldInput &&
other.name == name &&
other.type == type &&
other.defaultValue == other.defaultValue &&
other.defaultsToNull == defaultsToNull &&
other.description == description;
2018-08-02 13:31:54 +00:00
}