diff --git a/rollup.config.mjs b/rollup.config.mjs index 5b4d42d..f44666c 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -5,7 +5,6 @@ import commonjs from '@rollup/plugin-commonjs' import nodePolyfills from 'rollup-plugin-polyfill-node' import resolve from '@rollup/plugin-node-resolve' import json from '@rollup/plugin-json' - import {createRequire} from 'module' const require = createRequire(import.meta.url) const pkg = require('./package.json') @@ -30,10 +29,11 @@ export default [ input: 'src/index.ts', output: { banner, - file: pkg.main, + dir: pkg.main, format: 'cjs', sourcemap: true, exports: 'named', + entryFileNames: '[name].js', }, plugins: [ typescript({target: 'es6'}), @@ -50,9 +50,10 @@ export default [ input: 'src/index.ts', output: { banner, - file: pkg.module, + dir: pkg.main, format: 'esm', sourcemap: true, + entryFileNames: '[name].m.js', }, plugins: [ typescript({target: 'es2020'}), @@ -67,7 +68,7 @@ export default [ }, { input: 'src/index.ts', - output: {banner, file: pkg.types, format: 'esm'}, + output: {banner, dir: pkg.main, format: 'esm', entryFileNames: '[name].d.ts'}, plugins: [dts()], }, ] diff --git a/src/index.ts b/src/index.ts index cdf5682..f6a4b39 100644 --- a/src/index.ts +++ b/src/index.ts @@ -10,7 +10,6 @@ import { WalletPluginMetadata, WalletPluginSignResponse, } from '@wharfkit/session' -import {handleLogin, handleLogout, handleSignatureRequest} from '@wharfkit/protocol-scatter' export class WalletPluginWombat extends AbstractWalletPlugin implements WalletPlugin { id = 'wombat' @@ -38,26 +37,30 @@ export class WalletPluginWombat extends AbstractWalletPlugin implements WalletPl readonly metadata: WalletPluginMetadata = WalletPluginMetadata.from({ name: 'Wombat', description: '', - logo: '', + logo: '', homepage: 'https://www.wombat.app/', download: 'https://www.wombat.app/the-app', }) + + private async loadScatterProtocol() { + if (typeof window !== 'undefined') { + return import('@wharfkit/protocol-scatter') + } + return null + } + /** * Performs the wallet logic required to login and return the chain and permission level to use. * * @param context LoginContext * @returns Promise */ - login(context: LoginContext): Promise { - return new Promise((resolve, reject) => { - handleLogin(context) - .then((response) => { - resolve(response) - }) - .catch((error) => { - reject(error) - }) - }) + async login(context: LoginContext): Promise { + const scatterProtocol = await this.loadScatterProtocol() + if (!scatterProtocol) { + throw new Error('Scatter protocol is not available in this environment') + } + return scatterProtocol.handleLogin(context) } /** @@ -66,17 +69,12 @@ export class WalletPluginWombat extends AbstractWalletPlugin implements WalletPl * @param context: LogoutContext * @returns Promise */ - - logout(context: LogoutContext): Promise { - return new Promise((resolve, reject) => { - handleLogout(context) - .then(() => { - resolve() - }) - .catch((error) => { - reject(error) - }) - }) + async logout(context: LogoutContext): Promise { + const scatterProtocol = await this.loadScatterProtocol() + if (!scatterProtocol) { + throw new Error('Scatter protocol is not available in this environment') + } + return scatterProtocol.handleLogout(context) } /** @@ -86,10 +84,14 @@ export class WalletPluginWombat extends AbstractWalletPlugin implements WalletPl * @param resolved ResolvedSigningRequest * @returns Promise */ - sign( + async sign( resolved: ResolvedSigningRequest, context: TransactContext ): Promise { - return handleSignatureRequest(resolved, context) + const scatterProtocol = await this.loadScatterProtocol() + if (!scatterProtocol) { + throw new Error('Scatter protocol is not available in this environment') + } + return scatterProtocol.handleSignatureRequest(resolved, context) } }