Skip to content

Commit

Permalink
Generate optional TypeScript fields when @include directive is used
Browse files Browse the repository at this point in the history
  • Loading branch information
mwilliamson committed Apr 19, 2020
1 parent 045742e commit 2550fc1
Show file tree
Hide file tree
Showing 5 changed files with 68 additions and 8 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
- `apollo-codegen-swift`
- <First `apollo-codegen-swift` related entry goes here>
- `apollo-codegen-typescript`
- <First `apollo-codegen-typescript` related entry goes here>
- Generate optional TypeScript fields when @include directive is used [#1854](https://github.com/apollographql/apollo-tooling/pull/1854)
- `apollo-codegen-core`
- <First `apollo-codegen-core` related entry goes here>
- `apollo-env`
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,48 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`Typescript codeGeneration @include directive 1`] = `
Object {
"common": "/* tslint:disable */
/* eslint-disable */
// @generated
// This file was automatically generated and should not be edited.
//==============================================================
// START Enums and Input Objects
//==============================================================
//==============================================================
// END Enums and Input Objects
//==============================================================
",
"generatedFiles": Array [
Object {
"content": TypescriptGeneratedFile {
"fileContents": "/* tslint:disable */
/* eslint-disable */
// @generated
// This file was automatically generated and should not be edited.
// ====================================================
// GraphQL fragment: SimpleFragment
// ====================================================
export interface SimpleFragment {
__typename: \\"Human\\" | \\"Droid\\";
/**
* The name of the character
*/
name?: string;
}
",
},
"fileName": "SimpleFragment.ts",
"sourcePath": "GraphQL request",
},
],
}
`;

exports[`Typescript codeGeneration fragment spreads with inline fragments 1`] = `
Object {
"common": "/* tslint:disable */
Expand Down
11 changes: 11 additions & 0 deletions packages/apollo-codegen-typescript/src/__tests__/codeGeneration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -286,6 +286,17 @@ describe("Typescript codeGeneration", () => {
const output = generateSource(context);
expect(output).toMatchSnapshot();
});

test("@include directive", () => {
const context = compile(`
fragment SimpleFragment on Character{
name @include(if: $includeName)
}
`);

const output = generateSource(context);
expect(output).toMatchSnapshot();
});
});

describe("Typescript codeGeneration local / global", () => {
Expand Down
12 changes: 8 additions & 4 deletions packages/apollo-codegen-typescript/src/codeGeneration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -285,7 +285,8 @@ export class TypescriptAPIGenerator extends TypescriptGenerator {
interfaceName,
variables.map(variable => ({
name: variable.name,
type: this.typeFromGraphQLType(variable.type)
type: this.typeFromGraphQLType(variable.type),
isConditional: false
})),
{ keyInheritsNullability: true }
)
Expand Down Expand Up @@ -559,7 +560,8 @@ export class TypescriptAPIGenerator extends TypescriptGenerator {
return {
name: field.alias ? field.alias : field.name,
description: field.description,
type
type,
isConditional: field.isConditional || false
};
}

Expand All @@ -573,14 +575,16 @@ export class TypescriptAPIGenerator extends TypescriptGenerator {
res = {
name: field.alias ? field.alias : field.name,
description: field.description,
type: t.TSUnionType(types)
type: t.TSUnionType(types),
isConditional: field.isConditional || false
};
} else {
// TODO: Double check that this works
res = {
name: field.alias ? field.alias : field.name,
description: field.description,
type: this.typeFromGraphQLType(field.type)
type: this.typeFromGraphQLType(field.type),
isConditional: field.isConditional || false
};
}

Expand Down
8 changes: 5 additions & 3 deletions packages/apollo-codegen-typescript/src/language.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ export type ObjectProperty = {
name: string;
description?: string | null | undefined;
type: t.TSType;
isConditional: boolean;
};

export default class TypescriptGenerator {
Expand Down Expand Up @@ -61,7 +62,8 @@ export default class TypescriptGenerator {
const field = fieldMap[fieldName];
return {
name: fieldName,
type: this.typeFromGraphQLType(field.type)
type: this.typeFromGraphQLType(field.type),
isConditional: false
};
});

Expand Down Expand Up @@ -92,15 +94,15 @@ export default class TypescriptGenerator {
keyInheritsNullability?: boolean;
} = {}
) {
return fields.map(({ name, description, type }) => {
return fields.map(({ name, description, type, isConditional }) => {
const propertySignatureType = t.TSPropertySignature(
t.identifier(name),
t.TSTypeAnnotation(type)
);

// TODO: Check if this works
propertySignatureType.optional =
keyInheritsNullability && this.isNullableType(type);
(keyInheritsNullability && this.isNullableType(type)) || isConditional;

if (this.options.useReadOnlyTypes) {
propertySignatureType.readonly = true;
Expand Down

0 comments on commit 2550fc1

Please sign in to comment.