From 0077f38e39840674042eaa5074ccbc01aa97af70 Mon Sep 17 00:00:00 2001 From: Dallas Johnson Date: Tue, 8 Oct 2019 01:12:37 +0100 Subject: [PATCH] Create typescript type defs which allow nested types in actions parameters and tables. --- src/contracts/typeGenerator.ts | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/src/contracts/typeGenerator.ts b/src/contracts/typeGenerator.ts index a3c7788..e12ec56 100644 --- a/src/contracts/typeGenerator.ts +++ b/src/contracts/typeGenerator.ts @@ -17,10 +17,13 @@ type GeneratorLevel = Array; * @author Mitch Pierias * @param eosType */ -export const mapParameterType = (eosType: string) => { +export const mapParameterType = (contractName: string, contractStructs: any, eosType: string) => { // Handle array types const wrapper = eosType.endsWith('[]') ? 'Array' : undefined; - const type = mapTypes[eosType.replace('[]', '')] || 'string'; + const parameterType = eosType.replace('[]', ''); + const type = contractStructs[parameterType] + ? pascalCase(contractName) + pascalCase(parameterType) + : mapTypes[parameterType] || 'string'; if (wrapper) { return `${wrapper}<${type}>`; } else { @@ -87,22 +90,22 @@ export const generateTypes = async (contractIdentifier: string) => { result.push(`import { ${imports.join(', ')} } from 'lamington';`); result.push(''); result.push('// Table row types'); - // Generate table row types from ABI - for (const table of contractTables) { - const tableInterface = { - [`export interface ${pascalCase(contractName)}${pascalCase(table.name)}`]: contractStructs[ - table.type - ].fields.map((field: any) => `${field.name}: ${mapParameterType(field.type)};`), + // Generate structs from ABI + for (const key in contractStructs) { + const structInterface = { + [`export interface ${pascalCase(contractName)}${pascalCase(key)}`]: contractStructs[key].fields.map( + (field: any) => `${field.name}: ${mapParameterType(contractName, {}, field.type)};` + ), }; - result.push(tableInterface); + result.push(structInterface); result.push(''); } // Generate contract type from ABI const generatedContractActions = contractActions.map((action: any) => { // With a function for each action const parameters = contractStructs[action.name].fields.map( - (parameter: any) => `${parameter.name}: ${mapParameterType(parameter.type)}` + (parameter: any) => `${parameter.name}: ${mapParameterType(contractName, contractStructs, parameter.type)}` ); // Optional parameter at the end on every contract method. parameters.push('options?: { from?: Account, auths?: ActorPermission[] }'); @@ -112,11 +115,7 @@ export const generateTypes = async (contractIdentifier: string) => { // Generate tables const generatedTables = contractTables.map( (table: any) => - `${camelCase( - table.name - )}(options?: GetTableRowsOptions): Promise>;` + `${camelCase(table.name) + 'Table'}(options?: GetTableRowsOptions): Promise>;` ); // Generate the contract interface with actions and tables const contractInterface = {