diff --git a/packages/react-native-codegen/src/parsers/__tests__/parsers-primitives-test.js b/packages/react-native-codegen/src/parsers/__tests__/parsers-primitives-test.js index 8d22808443cdf4..c3f73de65da177 100644 --- a/packages/react-native-codegen/src/parsers/__tests__/parsers-primitives-test.js +++ b/packages/react-native-codegen/src/parsers/__tests__/parsers-primitives-test.js @@ -16,9 +16,10 @@ const { emitDouble, emitNumber, emitInt32, + emitObject, + emitPromise, emitRootTag, typeAliasResolution, - emitPromise, } = require('../parsers-primitives.js'); describe('emitBoolean', () => { @@ -315,3 +316,29 @@ describe('emitPromise', () => { }); }); }); + +describe('emitObject', () => { + describe('when nullable is true', () => { + it('returns nullable type annotation', () => { + const result = emitObject(true); + const expected = { + type: 'NullableTypeAnnotation', + typeAnnotation: { + type: 'GenericObjectTypeAnnotation', + }, + }; + + expect(result).toEqual(expected); + }); + }); + describe('when nullable is false', () => { + it('returns non nullable type annotation', () => { + const result = emitObject(false); + const expected = { + type: 'GenericObjectTypeAnnotation', + }; + + expect(result).toEqual(expected); + }); + }); +}); diff --git a/packages/react-native-codegen/src/parsers/flow/modules/index.js b/packages/react-native-codegen/src/parsers/flow/modules/index.js index 3597f261498dea..ad9de4acf4d0d8 100644 --- a/packages/react-native-codegen/src/parsers/flow/modules/index.js +++ b/packages/react-native-codegen/src/parsers/flow/modules/index.js @@ -42,9 +42,10 @@ const { emitDouble, emitNumber, emitInt32, + emitObject, + emitPromise, emitRootTag, typeAliasResolution, - emitPromise, } = require('../../parsers-primitives'); const { MisnamedModuleInterfaceParserError, @@ -218,9 +219,7 @@ function translateTypeAnnotation( } case 'UnsafeObject': case 'Object': { - return wrapNullable(nullable, { - type: 'GenericObjectTypeAnnotation', - }); + return emitObject(nullable); } default: { const maybeEumDeclaration = types[typeAnnotation.id.name]; diff --git a/packages/react-native-codegen/src/parsers/parsers-primitives.js b/packages/react-native-codegen/src/parsers/parsers-primitives.js index b497d1398572b0..8a0b4fc341d49b 100644 --- a/packages/react-native-codegen/src/parsers/parsers-primitives.js +++ b/packages/react-native-codegen/src/parsers/parsers-primitives.js @@ -19,6 +19,7 @@ import type { BooleanTypeAnnotation, DoubleTypeAnnotation, Int32TypeAnnotation, + NativeModuleGenericObjectTypeAnnotation, ReservedTypeAnnotation, ObjectTypeAnnotation, NativeModulePromiseTypeAnnotation, @@ -135,12 +136,21 @@ function emitPromise( }); } +function emitObject( + nullable: boolean, +): Nullable { + return wrapNullable(nullable, { + type: 'GenericObjectTypeAnnotation', + }); +} + module.exports = { emitBoolean, emitDouble, emitInt32, emitNumber, + emitObject, + emitPromise, emitRootTag, typeAliasResolution, - emitPromise, }; diff --git a/packages/react-native-codegen/src/parsers/typescript/modules/index.js b/packages/react-native-codegen/src/parsers/typescript/modules/index.js index 5d73f31d5f61ec..37dc652ffad45c 100644 --- a/packages/react-native-codegen/src/parsers/typescript/modules/index.js +++ b/packages/react-native-codegen/src/parsers/typescript/modules/index.js @@ -42,9 +42,10 @@ const { emitDouble, emitNumber, emitInt32, + emitObject, + emitPromise, emitRootTag, typeAliasResolution, - emitPromise, } = require('../../parsers-primitives'); const { MisnamedModuleInterfaceParserError, @@ -251,9 +252,7 @@ function translateTypeAnnotation( } case 'UnsafeObject': case 'Object': { - return wrapNullable(nullable, { - type: 'GenericObjectTypeAnnotation', - }); + return emitObject(nullable); } default: { const maybeEumDeclaration = types[typeAnnotation.typeName.name];