diff --git a/.changeset/smart-dingos-train.md b/.changeset/smart-dingos-train.md new file mode 100644 index 00000000..9cdfd3dc --- /dev/null +++ b/.changeset/smart-dingos-train.md @@ -0,0 +1,6 @@ +--- +'@stacks/connect-ui': minor +'@stacks/connect': minor +--- + +Add iframe capable Asigna provider. diff --git a/packages/connect-ui/src/components/modal/modal.tsx b/packages/connect-ui/src/components/modal/modal.tsx index 7d99a4d9..ff6ab0ab 100644 --- a/packages/connect-ui/src/components/modal/modal.tsx +++ b/packages/connect-ui/src/components/modal/modal.tsx @@ -204,7 +204,7 @@ export class Modal { rel="noopener noreferrer" target="_blank" > - Install → + {provider.id === 'AsignaProvider' ? 'Open' : 'Install'} → )} diff --git a/packages/connect/src/asigna.ts b/packages/connect/src/asigna.ts new file mode 100644 index 00000000..87ef2176 --- /dev/null +++ b/packages/connect/src/asigna.ts @@ -0,0 +1,33 @@ +const source = 'asigna-stx'; + +const generateCall = (payload: string, key: string) => { + return new Promise(res => { + function listener(message: MessageEvent) { + if (message.data.source === source && message.data[key]) { + res(message.data[key]); + window.removeEventListener('message', listener); + } + } + window.addEventListener('message', listener); + window.top.postMessage(generateAsignaMessage(payload, key), '*'); + }); +}; + +const AsignaIframeProvider = { + authenticationRequest: async (payload: string) => { + return generateCall(payload, 'authenticationRequest'); + }, + transactionRequest: async (payload: string) => { + return generateCall(payload, 'transactionRequest'); + }, +}; +const generateAsignaMessage = (payload: string, key: string) => { + return { source, [key]: payload }; +}; + +export const initializeAsignaProvider = () => { + const isAsignaIframe = !!window.top && document.referrer.endsWith('.asigna.io/'); + if (isAsignaIframe) { + window['AsignaProvider'] = AsignaIframeProvider; + } +}; diff --git a/packages/connect/src/providers.ts b/packages/connect/src/providers.ts index 006e0adb..459d1dfb 100644 --- a/packages/connect/src/providers.ts +++ b/packages/connect/src/providers.ts @@ -1,4 +1,7 @@ import { WebBTCProvider } from '@stacks/connect-ui'; +import { initializeAsignaProvider } from './asigna'; + +initializeAsignaProvider(); export const DEFAULT_PROVIDERS: WebBTCProvider[] = [ { @@ -25,10 +28,9 @@ export const DEFAULT_PROVIDERS: WebBTCProvider[] = [ }, { id: 'AsignaProvider', - name: 'Asigna', + name: 'Asigna Multisig', icon: '', webUrl: 'https://asigna.io', - chromeWebStoreUrl: - 'https://chromewebstore.google.com/detail/asigna-multisig/gopddoinbenlokghakiafackadkbnlid', + chromeWebStoreUrl: 'https://stx.asigna.io/', }, ];