Update Sollet Extension
This commit is contained in:
parent
c887be818c
commit
ec9bc85750
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "Sollet",
|
"name": "Sollet",
|
||||||
"description": "Solana SPL Token Wallet",
|
"description": "Solana SPL Token Wallet",
|
||||||
"version": "0.3.0",
|
"version": "0.3.1",
|
||||||
"browser_action": {
|
"browser_action": {
|
||||||
"default_popup": "index.html",
|
"default_popup": "index.html",
|
||||||
"default_title": "Open the popup"
|
"default_title": "Open the popup"
|
||||||
|
@ -14,14 +14,20 @@
|
||||||
},
|
},
|
||||||
"background": {
|
"background": {
|
||||||
"persistent": true,
|
"persistent": true,
|
||||||
"scripts": ["background.js"]
|
"scripts": [
|
||||||
|
"background.js"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"permissions": [
|
"permissions": [
|
||||||
"storage"
|
"storage"
|
||||||
],
|
],
|
||||||
"content_scripts": [
|
"content_scripts": [
|
||||||
{
|
{
|
||||||
"matches": ["file://*/*", "http://*/*", "https://*/*"],
|
"matches": [
|
||||||
|
"file://*/*",
|
||||||
|
"http://*/*",
|
||||||
|
"https://*/*"
|
||||||
|
],
|
||||||
"js": [
|
"js": [
|
||||||
"contentscript.js"
|
"contentscript.js"
|
||||||
],
|
],
|
||||||
|
@ -29,7 +35,8 @@
|
||||||
"all_frames": true
|
"all_frames": true
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"web_accessible_resources": ["script.js"],
|
"web_accessible_resources": [
|
||||||
|
"script.js"
|
||||||
|
],
|
||||||
"content_security_policy": "script-src 'self' 'sha256-ek+jXksbUr00x+EdLLqiv69t8hATh5rPjHVvVVGA9ms='; object-src 'self'"
|
"content_security_policy": "script-src 'self' 'sha256-ek+jXksbUr00x+EdLLqiv69t8hATh5rPjHVvVVGA9ms='; object-src 'self'"
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,6 +70,7 @@ export default function NavigationFrame({ children }) {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<AppBar position="static">
|
<AppBar position="static">
|
||||||
|
{!isExtension && (
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
textAlign: 'center',
|
textAlign: 'center',
|
||||||
|
@ -85,6 +86,7 @@ export default function NavigationFrame({ children }) {
|
||||||
services.
|
services.
|
||||||
</Typography>
|
</Typography>
|
||||||
</div>
|
</div>
|
||||||
|
)}
|
||||||
<Toolbar>
|
<Toolbar>
|
||||||
<Typography variant="h6" className={classes.title} component="h1">
|
<Typography variant="h6" className={classes.title} component="h1">
|
||||||
{isExtensionWidth ? 'Sollet' : 'Solana SPL Token Wallet'}
|
{isExtensionWidth ? 'Sollet' : 'Solana SPL Token Wallet'}
|
||||||
|
|
|
@ -10,7 +10,6 @@ import SwapHoriz from '@material-ui/icons/SwapHoriz';
|
||||||
import PopupState, { bindTrigger, bindPopover } from 'material-ui-popup-state';
|
import PopupState, { bindTrigger, bindPopover } from 'material-ui-popup-state';
|
||||||
import Swap from '@project-serum/swap-ui';
|
import Swap from '@project-serum/swap-ui';
|
||||||
import { Provider } from '@project-serum/anchor';
|
import { Provider } from '@project-serum/anchor';
|
||||||
import { Connection, TransactionSignature } from '@solana/web3.js';
|
|
||||||
import { TokenListContainer } from '@solana/spl-token-registry';
|
import { TokenListContainer } from '@solana/spl-token-registry';
|
||||||
import { useTokenInfos } from '../utils/tokens/names';
|
import { useTokenInfos } from '../utils/tokens/names';
|
||||||
import { useSendTransaction } from '../utils/notifications';
|
import { useSendTransaction } from '../utils/notifications';
|
||||||
|
@ -22,9 +21,9 @@ import DialogForm from './DialogForm';
|
||||||
export default function SwapButton({ size }) {
|
export default function SwapButton({ size }) {
|
||||||
const isExtensionWidth = useIsExtensionWidth();
|
const isExtensionWidth = useIsExtensionWidth();
|
||||||
if (isExtensionWidth) {
|
if (isExtensionWidth) {
|
||||||
return <SwapButtonDialog />;
|
return <SwapButtonDialog size={size} />;
|
||||||
} else {
|
} else {
|
||||||
return <SwapButtonPopover />;
|
return <SwapButtonPopover size={size} />;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,9 +118,9 @@ function SwapButtonPopover({ size }) {
|
||||||
|
|
||||||
class NotifyingProvider extends Provider {
|
class NotifyingProvider extends Provider {
|
||||||
constructor(
|
constructor(
|
||||||
connection: Connection,
|
connection,
|
||||||
wallet: Wallet,
|
wallet,
|
||||||
sendTransaction: (Promise<TransactionSignature>, Function) => void,
|
sendTransaction,
|
||||||
) {
|
) {
|
||||||
super(connection, wallet, {
|
super(connection, wallet, {
|
||||||
commitment: 'recent',
|
commitment: 'recent',
|
||||||
|
@ -130,10 +129,10 @@ class NotifyingProvider extends Provider {
|
||||||
}
|
}
|
||||||
|
|
||||||
async send(
|
async send(
|
||||||
tx: Transaction,
|
tx,
|
||||||
signers?: Array<Signer | undefined>,
|
signers,
|
||||||
opts?: ConfirmOptions,
|
opts,
|
||||||
): Promise<TransactionSignature> {
|
) {
|
||||||
return new Promise((onSuccess, onError) => {
|
return new Promise((onSuccess, onError) => {
|
||||||
this.sendTransaction(super.send(tx, signers, opts), {
|
this.sendTransaction(super.send(tx, signers, opts), {
|
||||||
onSuccess,
|
onSuccess,
|
||||||
|
@ -143,11 +142,11 @@ class NotifyingProvider extends Provider {
|
||||||
}
|
}
|
||||||
|
|
||||||
async sendAll(
|
async sendAll(
|
||||||
txs: Array<{ tx: Transaction, signers: Array<Signer | undefined> }>,
|
txs,
|
||||||
opts?: ConfirmOptions,
|
opts,
|
||||||
): Promise<Array<TransactionSignature>> {
|
) {
|
||||||
return new Promise(async (resolve, onError) => {
|
return new Promise(async (resolve, onError) => {
|
||||||
let txSigs: Array<TransactionSignature> = [];
|
let txSigs = [];
|
||||||
for (const tx of txs) {
|
for (const tx of txs) {
|
||||||
txSigs.push(
|
txSigs.push(
|
||||||
await new Promise((onSuccess) => {
|
await new Promise((onSuccess) => {
|
||||||
|
|
|
@ -117,6 +117,7 @@ const toInstruction = async (
|
||||||
);
|
);
|
||||||
} else if (programId.equals(RAYDIUM_STAKE_PROGRAM_ID)) {
|
} else if (programId.equals(RAYDIUM_STAKE_PROGRAM_ID)) {
|
||||||
console.log('[' + index + '] Handled as raydium stake instruction');
|
console.log('[' + index + '] Handled as raydium stake instruction');
|
||||||
|
// @ts-ignore
|
||||||
const decodedInstruction = decodeStakeInstruction(decoded);
|
const decodedInstruction = decodeStakeInstruction(decoded);
|
||||||
return await handleRayStakeInstruction(
|
return await handleRayStakeInstruction(
|
||||||
connection,
|
connection,
|
||||||
|
@ -126,6 +127,7 @@ const toInstruction = async (
|
||||||
);
|
);
|
||||||
} else if (programId.equals(RAYDIUM_LP_PROGRAM_ID)) {
|
} else if (programId.equals(RAYDIUM_LP_PROGRAM_ID)) {
|
||||||
console.log('[' + index + '] Handled as raydium lp instruction');
|
console.log('[' + index + '] Handled as raydium lp instruction');
|
||||||
|
// @ts-ignore
|
||||||
const decodedInstruction = decodeLpInstruction(decoded);
|
const decodedInstruction = decodeLpInstruction(decoded);
|
||||||
return await handleRayLpInstruction(
|
return await handleRayLpInstruction(
|
||||||
connection,
|
connection,
|
||||||
|
@ -135,6 +137,7 @@ const toInstruction = async (
|
||||||
);
|
);
|
||||||
} else if (programId.equals(MANGO_PROGRAM_ID) || programId.equals(MANGO_PROGRAM_ID_V2)) {
|
} else if (programId.equals(MANGO_PROGRAM_ID) || programId.equals(MANGO_PROGRAM_ID_V2)) {
|
||||||
console.log('[' + index + '] Handled as mango markets instruction');
|
console.log('[' + index + '] Handled as mango markets instruction');
|
||||||
|
// @ts-ignore
|
||||||
let decodedInstruction = decodeMangoInstruction(decoded);
|
let decodedInstruction = decodeMangoInstruction(decoded);
|
||||||
return await handleMangoInstruction(
|
return await handleMangoInstruction(
|
||||||
connection,
|
connection,
|
||||||
|
|
Loading…
Reference in New Issue