@ -4,7 +4,7 @@ import Gists from 'gists'
import { customAction } from '@remixproject/plugin-api/lib/file-system/file-panel/type'
import { customAction } from '@remixproject/plugin-api/lib/file-system/file-panel/type'
import { displayNotification , displayPopUp , fetchDirectoryError , fetchDirectoryRequest , fetchDirectorySuccess , focusElement , fsInitializationCompleted , hidePopUp , removeInputFieldSuccess , setCurrentWorkspace , setExpandPath , setMode , setWorkspaces } from './payload'
import { displayNotification , displayPopUp , fetchDirectoryError , fetchDirectoryRequest , fetchDirectorySuccess , focusElement , fsInitializationCompleted , hidePopUp , removeInputFieldSuccess , setCurrentWorkspace , setExpandPath , setMode , setWorkspaces } from './payload'
import { listenOnPluginEvents , listenOnProviderEvents } from './events'
import { listenOnPluginEvents , listenOnProviderEvents } from './events'
import { createWorkspaceTemplate , getWorkspaces , loadWorkspacePreset , setPlugin } from './workspace'
import { createWorkspaceTemplate , getWorkspaces , loadWorkspacePreset , setPlugin , workspaceExists } from './workspace'
import { QueryParams } from '@remix-project/remix-lib'
import { QueryParams } from '@remix-project/remix-lib'
import { fetchContractFromEtherscan } from '@remix-project/core-plugin' // eslint-disable-line
import { fetchContractFromEtherscan } from '@remix-project/core-plugin' // eslint-disable-line
import JSZip from 'jszip'
import JSZip from 'jszip'
@ -80,6 +80,7 @@ export const initWorkspace = (filePanelPlugin) => async (reducerDispatch: React.
{ id : 5 , name : 'goerli' }
{ id : 5 , name : 'goerli' }
]
]
let found = false
let found = false
let filePath
const foundOnNetworks = [ ]
const foundOnNetworks = [ ]
for ( const network of networks ) {
for ( const network of networks ) {
const target = ` / ${ network . name } / ${ contractAddress } `
const target = ` / ${ network . name } / ${ contractAddress } `
@ -95,15 +96,15 @@ export const initWorkspace = (filePanelPlugin) => async (reducerDispatch: React.
}
}
found = true
found = true
foundOnNetworks . push ( network . name )
foundOnNetworks . push ( network . name )
await createWorkspaceTemplate ( 'etherscan-code-sample' , 'code-template' )
if ( await workspaceExists ( 'etherscan-code-sample' ) ) workspaceProvider . setWorkspace ( 'etherscan-code-sample' )
else await createWorkspaceTemplate ( 'etherscan-code-sample' , 'code-template' )
plugin . setWorkspace ( { name : 'etherscan-code-sample' , isLocalhost : false } )
plugin . setWorkspace ( { name : 'etherscan-code-sample' , isLocalhost : false } )
dispatch ( setCurrentWorkspace ( { name : 'etherscan-code-sample' , isGitRepo : false } ) )
dispatch ( setCurrentWorkspace ( { name : 'etherscan-code-sample' , isGitRepo : false } ) )
let filePath
count = count + ( Object . keys ( data . compilationTargets ) ) . length
count = count + ( Object . keys ( data . compilationTargets ) ) . length
for ( filePath in data . compilationTargets )
for ( filePath in data . compilationTargets )
await workspaceProvider . set ( filePath , data . compilationTargets [ filePath ] [ 'content' ] )
await workspaceProvider . set ( filePath , data . compilationTargets [ filePath ] [ 'content' ] )
plugin . on ( 'editor' , 'editorMounted' , async ( ) = > await plugin . fileManager . openFile ( filePath ) )
}
}
plugin . on ( 'editor' , 'editorMounted' , async ( ) = > await plugin . fileManager . openFile ( filePath ) )
plugin . call ( 'notification' , 'toast' , ` Added ${ count } verified contract ${ count === 1 ? '' : 's' } from ${ foundOnNetworks . join ( ',' ) } network ${ foundOnNetworks . length === 1 ? '' : 's' } of Etherscan for contract address ${ contractAddress } !! ` )
plugin . call ( 'notification' , 'toast' , ` Added ${ count } verified contract ${ count === 1 ? '' : 's' } from ${ foundOnNetworks . join ( ',' ) } network ${ foundOnNetworks . length === 1 ? '' : 's' } of Etherscan for contract address ${ contractAddress } !! ` )
} catch ( error ) {
} catch ( error ) {
await basicWorkspaceInit ( workspaces , workspaceProvider )
await basicWorkspaceInit ( workspaces , workspaceProvider )