From 4ee900480d16e0b24fea1e1968b3c43bffa3aa64 Mon Sep 17 00:00:00 2001 From: "Michael Bradley, Jr" Date: Thu, 7 Nov 2019 07:44:10 -0600 Subject: [PATCH] fix(@cockpit/console): show contract names in the suggestions list Update event name `"deploy:contract:deployed"` to `"deployment:contract:deployed"`. Also, listen one time for `"deployment:deployContracts:afterAll"` and then request the full contracts list so as to pickup contract names that were already deployed. This is necessary for subsequent `embark run` (without reset), otherwise the suggestions list will be missing contracts. --- packages/core/console/src/lib/suggestions.ts | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/packages/core/console/src/lib/suggestions.ts b/packages/core/console/src/lib/suggestions.ts index 5c07b6cf9..5414624c6 100644 --- a/packages/core/console/src/lib/suggestions.ts +++ b/packages/core/console/src/lib/suggestions.ts @@ -1,4 +1,4 @@ -import { Embark, Events } /* supplied by @types/embark in packages/embark-typings */ from "embark"; +import { Contract, Embark, Events } /* supplied by @types/embark in packages/embark-typings */ from "embark"; import { fuzzySearch } from "embark-utils"; import { suggestions as defaultSuggestions } from "../../suggestions.json"; @@ -44,7 +44,7 @@ export default class Suggestions { this._suggestions = [...Suggestions.DEFAULT_SUGGESTIONS]; - Object.values(this.contracts).forEach((contract: any) => { + Object.values(this.contracts).forEach((contract: Contract) => { this._suggestions.push({value: contract.className, command_type: "web3 object", description: "contract deployed at " + contract.deployedAddress}); this._suggestions.push({value: "profile " + contract.className, command_type: "embark command", description: "profile " + contract.className + " contract"}); }); @@ -71,11 +71,17 @@ export default class Suggestions { } private listenToEvents() { - this.events.on("deploy:contract:deployed", (contract: any) => { - this.contracts[contract.className] = contract; + this.embark.events.once("deployment:deployContracts:afterAll", () => { + this.events.on("deployment:contract:deployed", ({contract}: {contract: Contract}) => { + this.contracts[contract.className] = contract; + // reset backing variable so contracts suggestions can be re-built for next request + this._suggestions = []; + }); - // reset backing variable so contracts suggestions can be re-built for next request - this._suggestions = []; + this.embark.events.request("contracts:list", (_: any, contracts: Contract[]) => { + contracts.forEach((contract) => { this.contracts[contract.className] = contract; }); + this._suggestions = []; + }); }); }