graphql-codegen-core
Advanced tools
Comparing version 0.6.0-alpha.b44f7c86 to 0.6.0-alpha.ba79dba1
"use strict"; | ||
var __assign = (this && this.__assign) || Object.assign || function(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) | ||
t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
@@ -8,2 +16,15 @@ var types_1 = require("../types"); | ||
var resolve_type_1 = require("../schema/resolve-type"); | ||
function separateSelectionSet(selectionSet) { | ||
var fields = selectionSet.filter(function (n) { return types_1.isFieldNode(n); }); | ||
var fragmentsSpread = selectionSet.filter(function (n) { return types_1.isFragmentSpreadNode(n); }); | ||
var inlineFragments = selectionSet.filter(function (n) { return types_1.isInlineFragmentNode(n); }); | ||
return { | ||
fragmentsSpread: fragmentsSpread, | ||
fields: fields, | ||
inlineFragments: inlineFragments, | ||
hasFragmentsSpread: fragmentsSpread.length > 0, | ||
hasFields: fields.length > 0, | ||
hasInlineFragments: inlineFragments.length > 0, | ||
}; | ||
} | ||
function buildSelectionSet(schema, rootObject, node) { | ||
@@ -16,19 +37,3 @@ return (node && node.selections ? node.selections : []).map(function (selectionNode) { | ||
var childSelectionSet = buildSelectionSet(schema, graphql_1.getNamedType(field.type), fieldNode.selectionSet); | ||
var fragmentsSpread = childSelectionSet.filter(function (n) { return types_1.isFragmentSpreadNode(n); }).map(function (fs) { return fs.fragmentName; }); | ||
var inlineFragments = childSelectionSet.filter(function (n) { return types_1.isInlineFragmentNode(n); }).map(function (fs) { return fs; }); | ||
return { | ||
isField: true, | ||
isFragmentSpread: false, | ||
isInlineFragment: false, | ||
isLeaf: childSelectionSet.length === 0, | ||
name: fieldNode.alias && fieldNode.alias.value ? fieldNode.alias.value : fieldNode.name.value, | ||
selectionSet: childSelectionSet, | ||
fragmentsSpread: fragmentsSpread, | ||
inlineFragments: inlineFragments, | ||
hasFragmentsSpread: fragmentsSpread.length > 0, | ||
hasInlineFragments: inlineFragments.length > 0, | ||
type: resolvedType.name, | ||
isRequired: resolvedType.isRequired, | ||
isArray: resolvedType.isArray, | ||
}; | ||
return __assign({ isField: true, isFragmentSpread: false, isInlineFragment: false, isLeaf: childSelectionSet.length === 0, name: fieldNode.alias && fieldNode.alias.value ? fieldNode.alias.value : fieldNode.name.value, selectionSet: childSelectionSet }, separateSelectionSet(childSelectionSet), { type: resolvedType.name, isRequired: resolvedType.isRequired, isArray: resolvedType.isArray }); | ||
} | ||
@@ -49,16 +54,3 @@ else if (selectionNode.kind === kinds_1.FRAGMENT_SPREAD) { | ||
var childSelectionSet = buildSelectionSet(schema, nextRoot, fieldNode.selectionSet); | ||
var fragmentsSpread = childSelectionSet.filter(function (n) { return types_1.isFragmentSpreadNode(n); }).map(function (fs) { return fs.fragmentName; }); | ||
var inlineFragments = childSelectionSet.filter(function (n) { return types_1.isInlineFragmentNode(n); }).map(function (fs) { return fs; }); | ||
return { | ||
isField: false, | ||
isFragmentSpread: false, | ||
isInlineFragment: true, | ||
isLeaf: childSelectionSet.length === 0, | ||
selectionSet: childSelectionSet, | ||
fragmentsSpread: fragmentsSpread, | ||
inlineFragments: inlineFragments, | ||
hasFragmentsSpread: fragmentsSpread.length > 0, | ||
hasInlineFragments: inlineFragments.length > 0, | ||
onType: fieldNode.typeCondition.name.value, | ||
}; | ||
return __assign({ isField: false, isFragmentSpread: false, isInlineFragment: true, isLeaf: childSelectionSet.length === 0, selectionSet: childSelectionSet }, separateSelectionSet(childSelectionSet), { onType: fieldNode.typeCondition.name.value }); | ||
} | ||
@@ -65,0 +57,0 @@ else { |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var graphql_1 = require("graphql"); | ||
var resolve_type_1 = require("./resolve-type"); | ||
var resolve_type_indicators_1 = require("./resolve-type-indicators"); | ||
function resolveArguments(args) { | ||
return args.map(function (arg) { | ||
var type = resolve_type_1.resolveType(arg.type); | ||
var namedType = graphql_1.getNamedType(arg.type); | ||
var indicators = resolve_type_indicators_1.resolveTypeIndicators(namedType); | ||
return { | ||
@@ -13,2 +17,8 @@ name: arg.name, | ||
isArray: type.isArray, | ||
isEnum: indicators.isEnum, | ||
isScalar: indicators.isScalar, | ||
isInterface: indicators.isInterface, | ||
isUnion: indicators.isUnion, | ||
isInputType: indicators.isInputType, | ||
isType: indicators.isType, | ||
}; | ||
@@ -15,0 +25,0 @@ }); |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var graphql_1 = require("graphql"); | ||
var object_map_to_array_1 = require("../utils/object-map-to-array"); | ||
var resolve_type_1 = require("./resolve-type"); | ||
var resolve_arguments_1 = require("./resolve-arguments"); | ||
var resolve_type_indicators_1 = require("./resolve-type-indicators"); | ||
function resolveFields(rawFields) { | ||
@@ -11,2 +13,4 @@ var fieldsArray = object_map_to_array_1.objectMapToArray(rawFields); | ||
var resolvedArguments = resolve_arguments_1.resolveArguments(item.value.args || []); | ||
var namedType = graphql_1.getNamedType(item.value.type); | ||
var indicators = resolve_type_indicators_1.resolveTypeIndicators(namedType); | ||
return { | ||
@@ -20,2 +24,8 @@ name: item.value.name, | ||
hasArguments: resolvedArguments.length > 0, | ||
isEnum: indicators.isEnum, | ||
isScalar: indicators.isScalar, | ||
isInterface: indicators.isInterface, | ||
isUnion: indicators.isUnion, | ||
isInputType: indicators.isInputType, | ||
isType: indicators.isType, | ||
}; | ||
@@ -22,0 +32,0 @@ }); |
@@ -7,2 +7,8 @@ export interface Argument { | ||
isArray: boolean; | ||
isType: boolean; | ||
isScalar: boolean; | ||
isInterface: boolean; | ||
isUnion: boolean; | ||
isInputType: boolean; | ||
isEnum: boolean; | ||
} | ||
@@ -17,2 +23,8 @@ export interface Field { | ||
hasArguments: boolean; | ||
isType: boolean; | ||
isScalar: boolean; | ||
isInterface: boolean; | ||
isUnion: boolean; | ||
isInputType: boolean; | ||
isEnum: boolean; | ||
} | ||
@@ -76,6 +88,8 @@ export interface Type { | ||
onType: string; | ||
fragmentsSpread: string[]; | ||
fields: SelectionSetFieldNode[]; | ||
fragmentsSpread: SelectionSetFragmentSpread[]; | ||
inlineFragments: SelectionSetInlineFragment[]; | ||
hasFragmentsSpread: boolean; | ||
hasInlineFragments: boolean; | ||
hasFields: boolean; | ||
} | ||
@@ -86,11 +100,13 @@ export interface SelectionSetFragmentSpread extends SelectionSetItem { | ||
export interface SelectionSetFieldNode extends SelectionSetItem { | ||
selectionSet: SelectionSetItem[]; | ||
name: string; | ||
selectionSet: SelectionSetItem[]; | ||
type: string; | ||
isRequired: boolean; | ||
isArray: boolean; | ||
fragmentsSpread: string[]; | ||
fields: SelectionSetFieldNode[]; | ||
fragmentsSpread: SelectionSetFragmentSpread[]; | ||
inlineFragments: SelectionSetInlineFragment[]; | ||
hasFragmentsSpread: boolean; | ||
hasInlineFragments: boolean; | ||
hasFields: boolean; | ||
} | ||
@@ -97,0 +113,0 @@ export declare function isFieldNode(node: SelectionSetItem): node is SelectionSetFieldNode; |
{ | ||
"name": "graphql-codegen-core", | ||
"version": "0.6.0-alpha.b44f7c86", | ||
"version": "0.6.0-alpha.ba79dba1", | ||
"description": "GraphQL types and code generator based on schema", | ||
"main": "dist/index.js", | ||
"scripts": { | ||
"build-tests": "tsc -p tsconfig.test.json", | ||
"watch": "tsc --watch", | ||
"clean": "rimraf ./dist", | ||
@@ -16,6 +14,2 @@ "lint": "tslint src/**/*.ts", | ||
"debug": "cd dist && node --inspect --debug-brk gql-gen.js", | ||
"changelog": "conventional-changelog -p angular -i CHANGELOG.md -s", | ||
"create-git-tag": "git tag $(cat package.json | json version)", | ||
"dev": "cd dist/cli && nodemon --ext ts,js,d.ts,template,graphql,json,handlebars gql-gen.js --dev --file ../../dev-test/githunt/schema.json --template ts --out ../../dev-test/githunt/typings.d.ts ../../dev-test/githunt/**/*.graphql", | ||
"prepare--": "npm run build && npm run test && npm run create-git-tag && git push && git push --tags", | ||
"test": "jest --no-cache --verbose --runInBand" | ||
@@ -22,0 +16,0 @@ }, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
235019
69
732