diff --git a/src/anchor.ts b/src/anchor.ts index 9afd4b2..a2267d4 100644 --- a/src/anchor.ts +++ b/src/anchor.ts @@ -9,7 +9,6 @@ import { LoginContext, PrivateKey, PublicKey, - ResolvedSigningRequest, Serializer, SigningRequest, UInt64, diff --git a/src/index.ts b/src/index.ts index 69110b3..4f6653d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -6,6 +6,7 @@ import { Canceled, Checksum256, LoginContext, + Logo, PermissionLevel, PrivateKey, PromptResponse, @@ -80,10 +81,10 @@ export class WalletPluginAnchor extends AbstractWalletPlugin { readonly metadata: WalletPluginMetadata = WalletPluginMetadata.from({ name: 'Anchor', description: '', - logo: { + logo: Logo.from({ dark: '', light: '', - }, + }), homepage: 'https://greymass.com/anchor', download: 'https://greymass.com/anchor/download', }) @@ -199,10 +200,10 @@ export class WalletPluginAnchor extends AbstractWalletPlugin { resolved: ResolvedSigningRequest, context: TransactContext ): Promise { - return this.handleSignatureRequest(resolved, context) + return this.handleSigningRequest(resolved, context) } - private async handleSignatureRequest( + private async handleSigningRequest( resolved: ResolvedSigningRequest, context: TransactContext ): Promise { @@ -224,6 +225,32 @@ export class WalletPluginAnchor extends AbstractWalletPlugin { // Add the callback to the request const callback = setTransactionCallback(modifiedRequest, this.buoyUrl) + const request = modifiedRequest.encode(true, false) + + const signManually = () => { + context.ui?.prompt({ + title: t('transact.sign_manually.title', {default: 'Sign manually'}), + body: t('transact.sign_manually.body', { + default: + 'Scan the QR-code with Anchor on another device or use the button to open it here.', + }), + elements: [ + { + type: 'qr', + data: String(request), + }, + { + type: 'link', + label: t('transact.sign_manually.link.title', {default: 'Open Anchor'}), + data: { + href: String(request), + label: t('transact.sign_manually.link.title', {default: 'Open Anchor'}), + }, + }, + ], + }) + } + // Tell Wharf we need to prompt the user with a QR code and a button const promptPromise: Cancelable = context.ui.prompt({ title: t('transact.title', {default: 'Complete using Anchor'}), @@ -240,10 +267,11 @@ export class WalletPluginAnchor extends AbstractWalletPlugin { }, }, { - type: 'link', + type: 'button', label: t('transact.label', {default: 'Sign manually or with another device'}), data: { href: modifiedRequest.encode(true, false, 'esr:'), + onClick: signManually, label: t('transact.label', { default: 'Sign manually or with another device', }), diff --git a/test/tests/anchor.ts b/test/tests/anchor.ts index 78a22dd..370dccb 100644 --- a/test/tests/anchor.ts +++ b/test/tests/anchor.ts @@ -36,7 +36,7 @@ suite('anchor', () => { test('sets the callback on the request and returns the callback data', async () => { const resolved = await makeMockResolvedSigningRequest() const buoyUrl = 'https://example.com/buoy' - const {service, channel} = setTransactionCallback(resolved, buoyUrl) + const {service, channel} = setTransactionCallback(resolved.request, buoyUrl) const resolvedCallback = resolved.getCallback([mockSignature1])