Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
B
baas-ide
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
guxukai
baas-ide
Commits
bf669ec8
Commit
bf669ec8
authored
Mar 14, 2019
by
Grandschtroumpf
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use ApiFactory and a getter for profile.
parent
1562d253
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
299 additions
and
255 deletions
+299
-255
app.js
src/app.js
+27
-36
plugin-manager-component.js
src/app/components/plugin-manager-component.js
+17
-16
SourceHighlighters.js
src/app/editor/SourceHighlighters.js
+5
-2
remixd-handle.js
src/app/files/remixd-handle.js
+5
-2
file-panel.js
src/app/panels/file-panel.js
+19
-14
analysis-tab.js
src/app/tabs/analysis-tab.js
+5
-2
compile-tab.js
src/app/tabs/compile-tab.js
+16
-13
debugger-tab.js
src/app/tabs/debugger-tab.js
+6
-2
run-tab.js
src/app/tabs/run-tab.js
+16
-12
settings-tab.js
src/app/tabs/settings-tab.js
+7
-3
support-tab.js
src/app/tabs/support-tab.js
+7
-2
test-tab.js
src/app/tabs/test-tab.js
+7
-2
txlistener-module.js
src/app/tabs/txlistener-module.js
+22
-0
generate.js
src/app/ui/landing-page/generate.js
+0
-73
landing-page.js
src/app/ui/landing-page/landing-page.js
+73
-5
universal-dapp.js
src/universal-dapp.js
+67
-71
No files found.
src/app.js
View file @
bf669ec8
...
...
@@ -7,7 +7,6 @@ var async = require('async')
var
request
=
require
(
'request'
)
var
remixLib
=
require
(
'remix-lib'
)
var
EventManager
=
require
(
'./lib/events'
)
var
EventEmitter
=
require
(
'events'
)
var
registry
=
require
(
'./global/registry'
)
var
UniversalDApp
=
require
(
'./universal-dapp.js'
)
var
UniversalDAppUI
=
require
(
'./universal-dapp-ui.js'
)
...
...
@@ -55,8 +54,10 @@ const FilePanel = require('./app/panels/file-panel')
import
PanelsResize
from
'./lib/panels-resize'
import
{
EntityStore
}
from
'./lib/store'
import
{
RemixAppManager
}
from
'./remixAppManager'
import
{
generateHomePage
,
homepageProfile
}
from
'./app/ui/landing-page/generat
e'
import
{
LandingPage
}
from
'./app/ui/landing-page/landing-pag
e'
import
framingService
from
'./framingService'
import
{
ApiFactory
}
from
'remix-plugin'
import
{
TxListenerModule
}
from
'./app/tabs/txlistener-module'
var
css
=
csjs
`
html { box-sizing: border-box; }
...
...
@@ -116,8 +117,9 @@ var css = csjs`
}
`
class
App
{
class
App
extends
ApiFactory
{
constructor
(
api
=
{},
events
=
{},
opts
=
{})
{
super
()
var
self
=
this
this
.
event
=
new
EventManager
()
self
.
_components
=
{}
...
...
@@ -173,7 +175,7 @@ class App {
run
.
apply
(
self
)
}
profile
()
{
get
profile
()
{
return
{
name
:
'app'
,
description
:
'service - provides information about current context (network).'
,
...
...
@@ -373,26 +375,13 @@ Please make a backup of your contracts and start using http://remix.ethereum.org
/*
that proxy is used by appManager to broadcast new transaction event
*/
const
txListenerModuleProxy
=
{
event
:
new
EventEmitter
(),
profile
()
{
return
{
name
:
'txListener'
,
displayName
:
'transaction listener'
,
events
:
[
'newTransaction'
],
description
:
'service - notify new transactions'
}
}
}
txlistener
.
event
.
register
(
'newTransaction'
,
(
tx
)
=>
{
txListenerModuleProxy
.
event
.
emit
(
'newTransaction'
,
tx
)
})
const
txListenerModule
=
new
TxListenerModule
(
txlistener
)
txlistener
.
startListening
()
// TODO: There are still a lot of dep between editorpanel and filemanager
let
appStore
=
new
EntityStore
(
'module'
,
{
actives
:
[],
ids
:
[],
entities
:
{}
}
)
let
appStore
=
new
EntityStore
(
'module'
,
'name'
)
const
appManager
=
new
RemixAppManager
(
appStore
)
registry
.
put
({
api
:
appManager
,
name
:
'appmanager'
})
...
...
@@ -458,33 +447,35 @@ Please make a backup of your contracts and start using http://remix.ethereum.org
let
settings
=
new
SettingsTab
(
self
.
_components
.
registry
)
let
analysis
=
new
AnalysisTab
(
registry
)
let
debug
=
new
DebuggerTab
()
const
landingPage
=
new
LandingPage
(
appManager
,
appStore
)
// let support = new SupportTab()
let
test
=
new
TestTab
(
self
.
_components
.
registry
,
compileTab
)
let
sourceHighlighters
=
registry
.
get
(
'editor'
).
api
.
sourceHighlighters
let
configProvider
=
self
.
_components
.
filesProviders
[
'config'
]
appManager
.
init
([
{
profile
:
homepageProfile
(),
api
:
generateHomePage
(
appManager
,
appStore
)
}
,
{
profile
:
this
.
profile
(),
api
:
this
}
,
{
profile
:
udapp
.
profile
(),
api
:
udapp
}
,
{
profile
:
fileManager
.
profile
(),
api
:
fileManager
}
,
{
profile
:
sourceHighlighters
.
profile
(),
api
:
sourceHighlighters
}
,
{
profile
:
configProvider
.
profile
(),
api
:
configProvider
}
,
{
profile
:
txListenerModuleProxy
.
profile
(),
api
:
txListenerModuleProxy
}
,
{
profile
:
filePanel
.
profile
(),
api
:
filePanel
}
,
this
.
api
()
,
landingPage
.
api
()
,
udapp
.
api
()
,
fileManager
.
api
()
,
sourceHighlighters
.
api
()
,
configProvider
.
api
()
,
txListenerModule
.
api
()
,
filePanel
.
api
()
,
// { profile: support.profile(), api: support },
{
profile
:
settings
.
profile
(),
api
:
settings
},
{
profile
:
pluginManagerComponent
.
profile
(),
api
:
pluginManagerComponent
}])
settings
.
api
(),
pluginManagerComponent
.
api
()
])
appManager
.
registerMany
([
{
profile
:
compileTab
.
profile
(),
api
:
compileTab
},
{
profile
:
run
.
profile
(),
api
:
run
},
{
profile
:
debug
.
profile
(),
api
:
debug
},
{
profile
:
analysis
.
profile
(),
api
:
analysis
},
{
profile
:
test
.
profile
(),
api
:
test
},
{
profile
:
filePanel
.
remixdHandle
.
profile
(),
api
:
filePanel
.
remixdHandle
}
compileTab
.
api
(),
run
.
api
(),
debug
.
api
(),
analysis
.
api
(),
test
.
api
(),
filePanel
.
remixdHandle
.
api
(),
...
appManager
.
plugins
()
])
appManager
.
registerMany
(
appManager
.
plugins
())
framingService
.
start
(
appStore
,
swapPanelApi
,
verticalIconsApi
,
mainPanelApi
,
this
.
_components
.
resizeFeature
)
...
...
src/app/components/plugin-manager-component.js
View file @
bf669ec8
...
...
@@ -2,7 +2,7 @@ const yo = require('yo-yo')
const
csjs
=
require
(
'csjs-inject'
)
const
EventEmitter
=
require
(
'events'
)
const
LocalPlugin
=
require
(
'./local-plugin'
)
import
{
Plugin
}
from
'remix-plugin'
import
{
Plugin
,
ApiFactory
}
from
'remix-plugin'
const
css
=
csjs
`
.pluginSearch {
...
...
@@ -34,9 +34,10 @@ const css = csjs`
}
`
class
PluginManagerComponent
{
class
PluginManagerComponent
extends
ApiFactory
{
constructor
()
{
super
()
this
.
event
=
new
EventEmitter
()
this
.
views
=
{
root
:
null
,
...
...
@@ -46,7 +47,7 @@ class PluginManagerComponent {
this
.
filter
=
''
}
profile
()
{
get
profile
()
{
return
{
displayName
:
'plugin manager'
,
name
:
'pluginManager'
,
...
...
@@ -71,10 +72,10 @@ class PluginManagerComponent {
}
renderItem
(
name
)
{
const
mod
=
this
.
store
.
getOne
(
name
)
if
(
!
mod
)
return
const
api
=
this
.
store
.
getOne
(
name
)
if
(
!
api
)
return
const
isActive
=
this
.
store
.
actives
.
includes
(
name
)
const
displayName
=
(
mod
.
profile
.
displayName
)
?
mod
.
profile
.
displayName
:
name
const
displayName
=
(
api
.
profile
.
displayName
)
?
api
.
profile
.
displayName
:
name
const
activationButton
=
isActive
?
yo
`
...
...
@@ -92,7 +93,7 @@ class PluginManagerComponent {
<h6 class="
${
css
.
displayName
}
">
${
displayName
}
</h6>
${
activationButton
}
</div>
<p class="
${
css
.
description
}
">
${
mod
.
profile
.
description
}
</p>
<p class="
${
css
.
description
}
">
${
api
.
profile
.
description
}
</p>
</article>
`
}
...
...
@@ -109,8 +110,8 @@ class PluginManagerComponent {
if
(
!
profile
)
return
const
resolveLocaton
=
(
iframe
)
=>
this
.
appManager
.
resolveLocation
(
profile
,
iframe
)
const
api
=
new
Plugin
(
profile
,
{
resolveLocaton
})
this
.
appManager
.
registerOne
(
{
profile
,
api
}
)
this
.
appManager
.
activateOne
(
profile
.
name
)
this
.
appManager
.
registerOne
(
api
)
this
.
appManager
.
activateOne
(
api
.
name
)
}
catch
(
err
)
{
// TODO : Use an alert to handle this error instead of a console.log
console
.
log
(
`Cannot create Plugin :
${
err
.
message
}
`
)
...
...
@@ -119,11 +120,11 @@ class PluginManagerComponent {
render
()
{
// Filtering helpers
const
isFiltered
=
(
{
profile
})
=>
profile
.
name
.
toLowerCase
().
includes
(
this
.
filter
)
const
isFiltered
=
(
api
)
=>
api
.
name
.
toLowerCase
().
includes
(
this
.
filter
)
const
isNotRequired
=
({
profile
})
=>
!
profile
.
required
const
sortByName
=
(
a
,
b
)
=>
{
const
nameA
=
a
.
profile
.
name
.
toUpperCase
()
const
nameB
=
b
.
profile
.
name
.
toUpperCase
()
const
nameA
=
a
.
name
.
toUpperCase
()
const
nameB
=
b
.
name
.
toUpperCase
()
return
(
nameA
<
nameB
)
?
-
1
:
(
nameA
>
nameB
)
?
1
:
0
}
...
...
@@ -132,10 +133,10 @@ class PluginManagerComponent {
.
filter
(
isFiltered
)
.
filter
(
isNotRequired
)
.
sort
(
sortByName
)
.
reduce
(({
actives
,
inactives
},
{
profile
}
)
=>
{
return
this
.
store
.
actives
.
includes
(
profile
.
name
)
?
{
actives
:
[...
actives
,
profile
.
name
],
inactives
}
:
{
inactives
:
[...
inactives
,
profile
.
name
],
actives
}
.
reduce
(({
actives
,
inactives
},
api
)
=>
{
return
this
.
store
.
actives
.
includes
(
api
.
name
)
?
{
actives
:
[...
actives
,
api
.
name
],
inactives
}
:
{
inactives
:
[...
inactives
,
api
.
name
],
actives
}
},
{
actives
:
[],
inactives
:
[]
})
const
activeTile
=
actives
.
length
!==
0
...
...
src/app/editor/SourceHighlighters.js
View file @
bf669ec8
'use strict'
const
SourceHighlighter
=
require
(
'./sourceHighlighter'
)
class
SourceHighlighters
{
import
{
ApiFactory
}
from
'remix-plugin'
class
SourceHighlighters
extends
ApiFactory
{
constructor
()
{
super
()
this
.
highlighters
=
{}
}
profile
()
{
get
profile
()
{
return
{
displayName
:
'source highlighters'
,
name
:
'sourceHighlighters'
,
...
...
src/app/files/remixd-handle.js
View file @
bf669ec8
import
{
ApiFactory
}
from
'remix-plugin'
var
yo
=
require
(
'yo-yo'
)
var
modalDialog
=
require
(
'../ui/modaldialog'
)
...
...
@@ -14,13 +16,14 @@ var css = csjs`
}
`
export
class
RemixdHandle
{
export
class
RemixdHandle
extends
ApiFactory
{
constructor
(
fileSystemExplorer
,
locahostProvider
)
{
super
()
this
.
fileSystemExplorer
=
fileSystemExplorer
this
.
locahostProvider
=
locahostProvider
}
profile
()
{
get
profile
()
{
return
{
name
:
'remixd'
,
methods
:
[],
...
...
src/app/panels/file-panel.js
View file @
bf669ec8
...
...
@@ -17,6 +17,8 @@ var globalRegistry = require('../../global/registry')
var
css
=
require
(
'./styles/file-panel-styles'
)
import
{
ApiFactory
}
from
'remix-plugin'
var
canUpload
=
window
.
File
||
window
.
FileReader
||
window
.
FileList
||
window
.
Blob
/*
...
...
@@ -36,7 +38,10 @@ var canUpload = window.File || window.FileReader || window.FileList || window.Bl
- call fileProvider API
*/
function
filepanel
(
localRegistry
)
{
module
.
exports
=
class
Filepanel
extends
ApiFactory
{
constructor
(
localRegistry
)
{
super
()
var
self
=
this
self
.
_components
=
{}
self
.
_components
.
registry
=
localRegistry
||
globalRegistry
...
...
@@ -163,18 +168,6 @@ function filepanel (localRegistry) {
self
.
render
=
function
render
()
{
return
element
}
self
.
profile
=
function
()
{
return
{
name
:
'fileExplorers'
,
displayName
:
'file explorers'
,
methods
:
[],
events
:
[],
icon
:
''
,
description
:
' - '
,
kind
:
'fileexplorer'
}
}
function
uploadFile
(
event
)
{
// TODO The file explorer is merely a view on the current state of
// the files module. Please ask the user here if they want to overwrite
...
...
@@ -317,6 +310,19 @@ function filepanel (localRegistry) {
})
}
}
}
get
profile
()
{
return
{
name
:
'fileExplorers'
,
displayName
:
'file explorers'
,
methods
:
[],
events
:
[],
icon
:
''
,
description
:
' - '
,
kind
:
'fileexplorer'
}
}
}
// return all the files, except the temporary/readonly ones..
...
...
@@ -340,4 +346,3 @@ function packageFiles (filesProvider, callback) {
})
}
module
.
exports
=
filepanel
src/app/tabs/analysis-tab.js
View file @
bf669ec8
...
...
@@ -3,13 +3,16 @@ var StaticAnalysis = require('../staticanalysis/staticAnalysisView')
var
EventManager
=
require
(
'../../lib/events'
)
var
css
=
require
(
'./styles/analysis-tab-styles'
)
class
AnalysisTab
{
import
{
ApiFactory
}
from
'remix-plugin'
class
AnalysisTab
extends
ApiFactory
{
constructor
(
registry
)
{
super
()
this
.
event
=
new
EventManager
()
this
.
registry
=
registry
}
profile
()
{
get
profile
()
{
return
{
name
:
'solidityStaticAnalysis'
,
displayName
:
'solidity static analysis'
,
...
...
src/app/tabs/compile-tab.js
View file @
bf669ec8
...
...
@@ -17,9 +17,12 @@ var css = require('./styles/compile-tab-styles')
const
CompileTabLogic
=
require
(
'./compileTab/compileTab.js'
)
const
CompilerContainer
=
require
(
'./compileTab/compilerContainer.js'
)
class
CompileTab
{
import
{
ApiFactory
}
from
'remix-plugin'
class
CompileTab
extends
ApiFactory
{
constructor
(
registry
)
{
super
()
this
.
events
=
new
EventEmitter
()
this
.
_view
=
{
el
:
null
,
...
...
@@ -56,6 +59,18 @@ class CompileTab {
)
}
get
profile
()
{
return
{
displayName
:
'solidity compiler'
,
name
:
'solidity'
,
methods
:
[
'getCompilationResult'
],
events
:
[
'compilationFinished'
],
icon
:
''
,
description
:
'compile solidity contracts'
,
kind
:
'compile'
}
}
activate
()
{
this
.
listenToEvents
()
this
.
compilerContainer
.
activate
()
...
...
@@ -131,18 +146,6 @@ class CompileTab {
})
}
profile
()
{
return
{
displayName
:
'solidity compiler'
,
name
:
'solidity'
,
methods
:
[
'getCompilationResult'
],
events
:
[
'compilationFinished'
],
icon
:
''
,
description
:
'compile solidity contracts'
,
kind
:
'compile'
}
}
getCompilationResult
()
{
return
new
Promise
((
resolve
,
reject
)
=>
{
resolve
(
this
.
compileTabLogic
.
compiler
.
lastCompilationResult
)
...
...
src/app/tabs/debugger-tab.js
View file @
bf669ec8
...
...
@@ -3,12 +3,16 @@ var css = require('./styles/debugger-tab-styles')
var
DebuggerUI
=
require
(
'../debugger/debuggerUI'
)
class
DebuggerTab
{
import
{
ApiFactory
}
from
'remix-plugin'
class
DebuggerTab
extends
ApiFactory
{
constructor
()
{
super
()
this
.
el
=
null
}
profile
()
{
get
profile
()
{
return
{
displayName
:
'debugger'
,
name
:
'debugger'
,
...
...
src/app/tabs/run-tab.js
View file @
bf669ec8
...
...
@@ -12,9 +12,12 @@ var ContractDropdownUI = require('./runTab/contractDropdown.js')
var
Recorder
=
require
(
'./runTab/model/recorder.js'
)
var
RecorderUI
=
require
(
'./runTab/recorder.js'
)
class
RunTab
{
import
{
ApiFactory
}
from
'remix-plugin'
class
RunTab
extends
ApiFactory
{
constructor
(
udapp
,
udappUI
,
config
,
fileManager
,
editor
,
logCallback
,
filePanel
,
pluginManager
,
compilersArtefacts
)
{
super
()
this
.
event
=
new
EventManager
()
this
.
renderInstanceContainer
()
...
...
@@ -25,6 +28,18 @@ class RunTab {
this
.
renderContainer
()
}
get
profile
()
{
return
{
name
:
'run'
,
displayName
:
'run transactions'
,
methods
:
[],
events
:
[],
icon
:
''
,
description
:
'execute and save transactions'
,
kind
:
'run'
}
}
renderContainer
()
{
this
.
container
=
yo
`<div class="
${
css
.
runTabView
}
" id="runTabView" ></div>`
...
...
@@ -147,17 +162,6 @@ class RunTab {
return
this
.
container
}
profile
()
{
return
{
name
:
'run'
,
displayName
:
'run transactions'
,
methods
:
[],
events
:
[],
icon
:
''
,
description
:
'execute and save transactions'
,
kind
:
'run'
}
}
}
module
.
exports
=
RunTab
src/app/tabs/settings-tab.js
View file @
bf669ec8
...
...
@@ -9,8 +9,11 @@ var styleGuide = require('../ui/styles-guide/theme-chooser')
var
Storage
=
remixLib
.
Storage
var
EventManager
=
require
(
'../../lib/events'
)
module
.
exports
=
class
SettingsTab
{
import
{
ApiFactory
}
from
'remix-plugin'
module
.
exports
=
class
SettingsTab
extends
ApiFactory
{
constructor
(
localRegistry
)
{
super
()
const
self
=
this
self
.
_components
=
{}
self
.
_components
.
registry
=
localRegistry
||
globalRegistry
...
...
@@ -37,7 +40,7 @@ module.exports = class SettingsTab {
self
.
_components
.
themeStorage
=
new
Storage
(
'style:'
)
self
.
data
.
currentTheme
=
self
.
_components
.
themeStorage
.
get
(
'theme'
)
||
'light'
}
profile
()
{
get
profile
()
{
return
{
displayName
:
'settings'
,
name
:
'settings'
,
...
...
@@ -45,7 +48,8 @@ module.exports = class SettingsTab {
events
:
[],
icon
:
''
,
description
:
' - '
,
kind
:
'settings'
kind
:
'settings'
,
location
:
'swapPanel'
,
}
}
render
()
{
...
...
src/app/tabs/support-tab.js
View file @
bf669ec8
const
yo
=
require
(
'yo-yo'
)
var
css
=
require
(
'./styles/support-tab-styles'
)
class
SupportTab
{
import
{
ApiFactory
}
from
'remix-plugin'
class
SupportTab
extends
ApiFactory
{
constructor
(
localRegistry
)
{
super
()
this
.
el
=
null
this
.
gitterIframe
=
''
this
.
gitterIsLoaded
=
false
...
...
@@ -18,7 +21,8 @@ class SupportTab {
this
.
el
.
style
.
display
=
'block'
this
.
gitterIsLoaded
=
true
}
profile
()
{
get
profile
()
{
return
{
name
:
'support'
,
methods
:
[],
...
...
@@ -27,6 +31,7 @@ class SupportTab {
description
:
'help center'
}
}
render
()
{
if
(
this
.
el
)
return
this
.
el
...
...
src/app/tabs/test-tab.js
View file @
bf669ec8
...
...
@@ -7,8 +7,11 @@ var globalRegistry = require('../../global/registry')
var
css
=
require
(
'./styles/test-tab-styles'
)
var
remixTests
=
require
(
'remix-tests'
)
module
.
exports
=
class
TestTab
{
import
{
ApiFactory
}
from
'remix-plugin'
module
.
exports
=
class
TestTab
extends
ApiFactory
{
constructor
(
localRegistry
,
compileTab
)
{
super
()
// TODO here is a direct reference to compile tab, should be removed
const
self
=
this
self
.
compileTab
=
compileTab
...
...
@@ -23,7 +26,8 @@ module.exports = class TestTab {
self
.
data
=
{}
self
.
testList
=
yo
`<div class=
${
css
.
testList
}
></div>`
}
profile
()
{
get
profile
()
{
return
{
name
:
'solidityUnitTesting'
,
displayName
:
'solidity unit testing'
,
...
...
@@ -33,6 +37,7 @@ module.exports = class TestTab {
description
:
' - '
}
}
render
()
{
const
self
=
this
var
testsOutput
=
yo
`<div class="
${
css
.
container
}
border border-primary border-right-0 border-left-0 border-bottom-0" hidden='true' id="tests"></div>`
...
...
src/app/tabs/txlistener-module.js
0 → 100644
View file @
bf669ec8
import
{
ApiFactory
}
from
'remix-plugin'
import
{
EventEmitter
}
from
'events'
export
class
TxListenerModule
extends
ApiFactory
{
constructor
(
txlistener
)
{
super
()
this
.
events
=
new
EventEmitter
()
txlistener
.
event
.
register
(
'newTransaction'
,
(
tx
)
=>
{
this
.
events
.
emit
(
'newTransaction'
,
tx
)
})
}
get
profile
()
{
return
{
name
:
'txListener'
,
displayName
:
'transaction listener'
,
events
:
[
'newTransaction'
],
description
:
'service - notify new transactions'
}
}
}
src/app/ui/landing-page/generate.js
deleted
100644 → 0
View file @
1562d253
/* global */
import
LandingPage
from
'./landing-page'
import
Section
from
'./section'
import
{
defaultWorkspaces
}
from
'./workspace'
export
function
homepageProfile
()
{
return
{
displayName
:
'home'
,
name
:
'home'
,
methods
:
[],
events
:
[],
description
:
' - '
,
icon
:
''
,
prefferedLocation
:
'mainPanel'
}
}
export
function
generateHomePage
(
appManager
,
appStore
)
{
/*
var actions1 = [
{label: 'new file', type: `callback`, payload: () => { alert(`-new file created-`) }},
{label: 'import from GitHub', type: `callback`, payload: () => { alert(`-imported from GitHub-`) }},
{label: 'import from gist', type: `callback`, payload: () => { alert(`-imported from gist-`) }}
]
var actions2 = [
{label: '...', type: `callback`, payload: () => { alert(`-...-`) }}
]
var actions3 = [
{label: 'Remix documentation', type: `link`, payload: `https://remix.readthedocs.io/en/latest/#`},
{label: 'GitHub repository', type: `link`, payload: `https://github.com/ethereum/remix-ide`},
{label: 'acces local file system (remixd)', type: `link`, payload: `https://remix.readthedocs.io/en/latest/tutorial_remixd_filesystem.html`},
{label: 'npm module for remixd', type: `link`, payload: `https://www.npmjs.com/package/remixd`},
{label: 'medium posts', type: `link`, payload: `https://medium.com/remix-ide`},
{label: 'tutorials', type: `link`, payload: `https://github.com/ethereum/remix-workshops`}
]
var actions4 = [
{label: 'Remix plugins & modules', type: `link`, payload: `https://github.com/ethereum/remix-plugin/blob/master/readme.md`},
{label: 'repository on GitHub', type: `link`, payload: `https://github.com/ethereum/remix-plugin`},
{label: 'examples', type: `link`, payload: `https://github.com/ethereum/remix-plugin/tree/master/examples`},
{label: 'build plugin for Remix', type: `link`, payload: `https://medium.com/remix-ide/build-a-plugin-for-remix-90d43b209c5a`}
]
var actions5 = [
{label: 'Gitter channel', type: `link`, payload: `https://gitter.im/ethereum/remix`},
{label: 'Stack Overflow', type: `link`, payload: `https://stackoverflow.com/questions/tagged/remix`},
{label: 'Reddit', type: `link`, payload: `https://www.reddit.com/r/ethdev/search?q=remix&restrict_sr=1`}
]
var section1 = new Section('Start', actions1)
var section2 = new Section('Recent', actions2)
var section3 = new Section('Learn', actions3)
var section4 = new Section('Plugins', actions4)
var section5 = new Section('Help', actions5)
*/
var
sectionsWorkspaces
=
[]
sectionsWorkspaces
.
push
({
label
:
'Close All Modules'
,
type
:
'callback'
,
payload
:
()
=>
{
appStore
.
getActives
()
.
filter
(({
profile
})
=>
!
profile
.
required
)
.
forEach
((
profile
)
=>
{
appManager
.
deactivateOne
(
profile
.
name
)
})
}})
defaultWorkspaces
(
appManager
).
forEach
((
workspace
)
=>
{
sectionsWorkspaces
.
push
({
label
:
workspace
.
title
,
type
:
'callback'
,
payload
:
()
=>
{
workspace
.
activate
()
}})
})
var
sectionWorkspace
=
new
Section
(
'Workspaces'
,
sectionsWorkspaces
)
return
new
LandingPage
([
sectionWorkspace
])
}
src/app/ui/landing-page/landing-page.js
View file @
bf669ec8
...
...
@@ -27,9 +27,79 @@ var css = csjs`
}
`
class
LandingPage
{
constructor
(
sections
)
{
this
.
sections
=
sections
import
{
defaultWorkspaces
}
from
'./workspace'
import
{
ApiFactory
}
from
'remix-plugin'
import
Section
from
'./section'
export
class
LandingPage
extends
ApiFactory
{
constructor
(
appManager
,
appStore
)
{
super
()
/*
var actions1 = [
{label: 'new file', type: `callback`, payload: () => { alert(`-new file created-`) }},
{label: 'import from GitHub', type: `callback`, payload: () => { alert(`-imported from GitHub-`) }},
{label: 'import from gist', type: `callback`, payload: () => { alert(`-imported from gist-`) }}
]
var actions2 = [
{label: '...', type: `callback`, payload: () => { alert(`-...-`) }}
]
var actions3 = [
{label: 'Remix documentation', type: `link`, payload: `https://remix.readthedocs.io/en/latest/#`},
{label: 'GitHub repository', type: `link`, payload: `https://github.com/ethereum/remix-ide`},
{label: 'acces local file system (remixd)', type: `link`, payload: `https://remix.readthedocs.io/en/latest/tutorial_remixd_filesystem.html`},
{label: 'npm module for remixd', type: `link`, payload: `https://www.npmjs.com/package/remixd`},
{label: 'medium posts', type: `link`, payload: `https://medium.com/remix-ide`},
{label: 'tutorials', type: `link`, payload: `https://github.com/ethereum/remix-workshops`}
]
var actions4 = [
{label: 'Remix plugins & modules', type: `link`, payload: `https://github.com/ethereum/remix-plugin/blob/master/readme.md`},
{label: 'repository on GitHub', type: `link`, payload: `https://github.com/ethereum/remix-plugin`},
{label: 'examples', type: `link`, payload: `https://github.com/ethereum/remix-plugin/tree/master/examples`},
{label: 'build plugin for Remix', type: `link`, payload: `https://medium.com/remix-ide/build-a-plugin-for-remix-90d43b209c5a`}
]
var actions5 = [
{label: 'Gitter channel', type: `link`, payload: `https://gitter.im/ethereum/remix`},
{label: 'Stack Overflow', type: `link`, payload: `https://stackoverflow.com/questions/tagged/remix`},
{label: 'Reddit', type: `link`, payload: `https://www.reddit.com/r/ethdev/search?q=remix&restrict_sr=1`}
]
var section1 = new Section('Start', actions1)
var section2 = new Section('Recent', actions2)
var section3 = new Section('Learn', actions3)
var section4 = new Section('Plugins', actions4)
var section5 = new Section('Help', actions5)
*/
const
sectionsWorkspaces
=
[]
sectionsWorkspaces
.
push
({
label
:
'Close All Modules'
,
type
:
'callback'
,
payload
:
()
=>
{
appStore
.
getActives
()
.
filter
(({
profile
})
=>
!
profile
.
required
)
.
forEach
((
profile
)
=>
{
appManager
.
deactivateOne
(
profile
.
name
)
})
}})
defaultWorkspaces
(
appManager
).
forEach
((
workspace
)
=>
{
sectionsWorkspaces
.
push
({
label
:
workspace
.
title
,
type
:
'callback'
,
payload
:
()
=>
{
workspace
.
activate
()
}})
})
const
sectionWorkspace
=
new
Section
(
'Workspaces'
,
sectionsWorkspaces
)
this
.
sections
=
sectionWorkspace
}
get
profile
()
{
return
{
displayName
:
'home'
,
name
:
'home'
,
methods
:
[],
events
:
[],
description
:
' - '
,
icon
:
''
,
location
:
'mainPanel'
}
}
render
()
{
...
...
@@ -48,5 +118,3 @@ class LandingPage {
return
totalLook
}
}
module
.
exports
=
LandingPage
src/universal-dapp.js
View file @
bf669ec8
...
...
@@ -7,38 +7,41 @@ var TxRunner = remixLib.execution.txRunner
var
txHelper
=
remixLib
.
execution
.
txHelper
var
EventManager
=
remixLib
.
EventManager
var
executionContext
=
remixLib
.
execution
.
executionContext
import
{
ApiFactory
}
from
'remix-plugin'
function
UniversalDApp
(
registry
)
{
module
.
exports
=
class
UniversalDApp
extends
ApiFactory
{
constructor
(
registry
)
{
super
()
this
.
event
=
new
EventManager
()
var
self
=
this
self
.
_deps
=
{
this
.
_deps
=
{
config
:
registry
.
get
(
'config'
).
api
}
self
.
_txRunnerAPI
=
{
config
:
self
.
_deps
.
config
,
this
.
_txRunnerAPI
=
{
config
:
this
.
_deps
.
config
,
detectNetwork
:
(
cb
)
=>
{
executionContext
.
detectNetwork
(
cb
)
},
personalMode
:
()
=>
{
return
self
.
_deps
.
config
.
get
(
'settings/personal-mode'
)
return
this
.
_deps
.
config
.
get
(
'settings/personal-mode'
)
}
}
self
.
txRunner
=
new
TxRunner
({},
self
.
_txRunnerAPI
)
self
.
accounts
=
{}
self
.
resetEnvironment
()
this
.
txRunner
=
new
TxRunner
({},
this
.
_txRunnerAPI
)
this
.
accounts
=
{}
this
.
resetEnvironment
()
executionContext
.
event
.
register
(
'contextChanged'
,
this
.
resetEnvironment
.
bind
(
this
))
}
}
UniversalDApp
.
prototype
.
profile
=
function
()
{
get
profile
()
{
return
{
name
:
'udapp'
,
displayName
:
'universal dapp'
,
methods
:
[
'runTestTx'
,
'getAccounts'
,
'createVMAccount'
],
description
:
'service - run transaction and access account'
}
}
}
UniversalDApp
.
prototype
.
resetEnvironment
=
function
()
{
resetEnvironment
()
{
this
.
accounts
=
{}
if
(
executionContext
.
isVM
())
{
this
.
_addAccount
(
'3cd7232cd6f3fc66a57a6bedc1a8ed6c228fff0a327e169c2bcc5e869ed49511'
,
'0x56BC75E2D63100000'
)
...
...
@@ -66,13 +69,13 @@ UniversalDApp.prototype.resetEnvironment = function () {
this
.
event
.
trigger
(
'transactionBroadcasted'
,
[
txhash
,
network
.
name
])
})
})
}
}
UniversalDApp
.
prototype
.
resetAPI
=
function
(
transactionContextAPI
)
{
resetAPI
(
transactionContextAPI
)
{
this
.
transactionContextAPI
=
transactionContextAPI
}
}
UniversalDApp
.
prototype
.
createVMAccount
=
function
(
privateKey
,
balance
,
cb
)
{
createVMAccount
(
privateKey
,
balance
,
cb
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
if
(
executionContext
.
getProvider
()
!==
'vm'
)
return
reject
(
'plugin API does not allow creating a new account through web3 connection. Only vm mode is allowed'
)
this
.
_addAccount
(
privateKey
,
balance
)
...
...
@@ -80,9 +83,9 @@ UniversalDApp.prototype.createVMAccount = function (privateKey, balance, cb) {
privateKey
=
Buffer
.
from
(
privateKey
,
'hex'
)
resolve
(
'0x'
+
ethJSUtil
.
privateToAddress
(
privateKey
).
toString
(
'hex'
))
})
}
}
UniversalDApp
.
prototype
.
newAccount
=
function
(
password
,
passwordPromptCb
,
cb
)
{
newAccount
(
password
,
passwordPromptCb
,
cb
)
{
if
(
!
executionContext
.
isVM
())
{
if
(
!
this
.
config
.
get
(
'settings/personal-mode'
))
{
return
cb
(
'Not running in personal mode'
)
...
...
@@ -99,28 +102,24 @@ UniversalDApp.prototype.newAccount = function (password, passwordPromptCb, cb) {
executionContext
.
vm
().
stateManager
.
cache
.
flush
(
function
()
{})
cb
(
null
,
'0x'
+
ethJSUtil
.
privateToAddress
(
privateKey
).
toString
(
'hex'
))
}
}
UniversalDApp
.
prototype
.
_addAccount
=
function
(
privateKey
,
balance
)
{
var
self
=
this
}
_addAccount
(
privateKey
,
balance
)
{
if
(
!
executionContext
.
isVM
())
{
throw
new
Error
(
'_addAccount() cannot be called in non-VM mode'
)
}
if
(
self
.
accounts
)
{
if
(
this
.
accounts
)
{
privateKey
=
Buffer
.
from
(
privateKey
,
'hex'
)
var
address
=
ethJSUtil
.
privateToAddress
(
privateKey
)
const
address
=
ethJSUtil
.
privateToAddress
(
privateKey
)
// FIXME: we don't care about the callback, but we should still make this proper
executionContext
.
vm
().
stateManager
.
putAccountBalance
(
address
,
balance
||
'0xf00000000000000001'
,
function
cb
()
{})
self
.
accounts
[
'0x'
+
address
.
toString
(
'hex'
)]
=
{
privateKey
:
privateKey
,
nonce
:
0
}
this
.
accounts
[
'0x'
+
address
.
toString
(
'hex'
)]
=
{
privateKey
,
nonce
:
0
}
}
}
}
// TODO should remove this cb
UniversalDApp
.
prototype
.
getAccounts
=
function
(
cb
)
{
var
self
=
this
getAccounts
(
cb
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
if
(
!
executionContext
.
isVM
())
{
// Weirdness of web3: listAccounts() is sync, `getListAccounts()` is async
...
...
@@ -139,24 +138,22 @@ UniversalDApp.prototype.getAccounts = function (cb) {
})
}
}
else
{
if
(
!
self
.
accounts
)
{
if
(
!
this
.
accounts
)
{
if
(
cb
)
cb
(
'No accounts?'
)
reject
(
'No accounts?'
)
return
}
if
(
cb
)
cb
(
null
,
Object
.
keys
(
self
.
accounts
))
resolve
(
Object
.
keys
(
self
.
accounts
))
if
(
cb
)
cb
(
null
,
Object
.
keys
(
this
.
accounts
))
resolve
(
Object
.
keys
(
this
.
accounts
))
}
})
}
UniversalDApp
.
prototype
.
getBalance
=
function
(
address
,
cb
)
{
var
self
=
this
}
getBalance
(
address
,
cb
)
{
address
=
ethJSUtil
.
stripHexPrefix
(
address
)
if
(
!
executionContext
.
isVM
())
{
executionContext
.
web3
().
eth
.
getBalance
(
address
,
function
(
err
,
res
)
{
executionContext
.
web3
().
eth
.
getBalance
(
address
,
(
err
,
res
)
=>
{
if
(
err
)
{
cb
(
err
)
}
else
{
...
...
@@ -164,11 +161,11 @@ UniversalDApp.prototype.getBalance = function (address, cb) {
}
})
}
else
{
if
(
!
self
.
accounts
)
{
if
(
!
this
.
accounts
)
{
return
cb
(
'No accounts?'
)
}
executionContext
.
vm
().
stateManager
.
getAccountBalance
(
Buffer
.
from
(
address
,
'hex'
),
function
(
err
,
res
)
{
executionContext
.
vm
().
stateManager
.
getAccountBalance
(
Buffer
.
from
(
address
,
'hex'
),
(
err
,
res
)
=>
{
if
(
err
)
{
cb
(
'Account not found'
)
}
else
{
...
...
@@ -176,37 +173,36 @@ UniversalDApp.prototype.getBalance = function (address, cb) {
}
})
}
}
}
UniversalDApp
.
prototype
.
getBalanceInEther
=
function
(
address
,
callback
)
{
var
self
=
this
self
.
getBalance
(
address
,
(
error
,
balance
)
=>
{
getBalanceInEther
(
address
,
callback
)
{
this
.
getBalance
(
address
,
(
error
,
balance
)
=>
{
if
(
error
)
{
callback
(
error
)
}
else
{
callback
(
null
,
executionContext
.
web3
().
fromWei
(
balance
,
'ether'
))
}
})
}
}
UniversalDApp
.
prototype
.
pendingTransactionsCount
=
function
()
{
pendingTransactionsCount
()
{
return
Object
.
keys
(
this
.
txRunner
.
pendingTxs
).
length
}
}
/**
/**
* deploy the given contract
*
* @param {String} data - data to send with the transaction ( return of txFormat.buildData(...) ).
* @param {Function} callback - callback.
*/
UniversalDApp
.
prototype
.
createContract
=
function
(
data
,
confirmationCb
,
continueCb
,
promptCb
,
callback
)
{
createContract
(
data
,
confirmationCb
,
continueCb
,
promptCb
,
callback
)
{
this
.
runTx
({
data
:
data
,
useCall
:
false
},
confirmationCb
,
continueCb
,
promptCb
,
(
error
,
txResult
)
=>
{
// see universaldapp.js line 660 => 700 to check possible values of txResult (error case)
callback
(
error
,
txResult
)
})
}
}
/**
/**
* call the current given contract
*
* @param {String} to - address of the contract to call.
...
...
@@ -214,39 +210,39 @@ UniversalDApp.prototype.createContract = function (data, confirmationCb, continu
* @param {Object} funAbi - abi definition of the function to call.
* @param {Function} callback - callback.
*/
UniversalDApp
.
prototype
.
callFunction
=
f
unction
(
to
,
data
,
funAbi
,
confirmationCb
,
continueCb
,
promptCb
,
callback
)
{
callF
unction
(
to
,
data
,
funAbi
,
confirmationCb
,
continueCb
,
promptCb
,
callback
)
{
this
.
runTx
({
to
:
to
,
data
:
data
,
useCall
:
funAbi
.
constant
},
confirmationCb
,
continueCb
,
promptCb
,
(
error
,
txResult
)
=>
{
// see universaldapp.js line 660 => 700 to check possible values of txResult (error case)
callback
(
error
,
txResult
)
})
}
}
UniversalDApp
.
prototype
.
context
=
function
()
{
context
()
{
return
(
executionContext
.
isVM
()
?
'memory'
:
'blockchain'
)
}
}
UniversalDApp
.
prototype
.
getABI
=
function
(
contract
)
{
getABI
(
contract
)
{
return
txHelper
.
sortAbiFunction
(
contract
.
abi
)
}
}
UniversalDApp
.
prototype
.
getFallbackInterface
=
function
(
contractABI
)
{
getFallbackInterface
(
contractABI
)
{
return
txHelper
.
getFallbackInterface
(
contractABI
)
}
}
UniversalDApp
.
prototype
.
getInputs
=
function
(
funABI
)
{
getInputs
(
funABI
)
{
if
(
!
funABI
.
inputs
)
{
return
''
}
return
txHelper
.
inputParametersDeclarationToString
(
funABI
.
inputs
)
}
}
/**
/**
* This function send a tx only to javascript VM or testnet, will return an error for the mainnet
* SHOULD BE TAKEN CAREFULLY!
*
* @param {Object} tx - transaction.
*/
UniversalDApp
.
prototype
.
runTestTx
=
function
(
tx
)
{
runTestTx
(
tx
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
executionContext
.
detectNetwork
((
error
,
network
)
=>
{
if
(
error
)
return
reject
(
error
)
...
...
@@ -266,26 +262,27 @@ UniversalDApp.prototype.runTestTx = function (tx) {
})
})
})
}
}
/**
/**
* This function send a tx without alerting the user (if mainnet or if gas estimation too high).
* SHOULD BE TAKEN CAREFULLY!
*
* @param {Object} tx - transaction.
* @param {Function} callback - callback.
*/
UniversalDApp
.
prototype
.
silentRunTx
=
function
(
tx
,
cb
)
{
silentRunTx
(
tx
,
cb
)
{
if
(
!
executionContext
.
isVM
())
return
cb
(
'Cannot silently send transaction through a web3 provider'
)
this
.
txRunner
.
rawRun
(
tx
,
(
network
,
tx
,
gasEstimation
,
continueTxExecution
,
cancelCb
)
=>
{
continueTxExecution
()
},
(
error
,
continueTxExecution
,
cancelCb
)
=>
{
if
(
error
)
{
cb
(
error
)
}
else
{
continueTxExecution
()
}
},
(
okCb
,
cancelCb
)
=>
{
okCb
()
},
cb
)
}
cb
)
}
UniversalDApp
.
prototype
.
runTx
=
function
(
args
,
confirmationCb
,
continueCb
,
promptCb
,
cb
)
{
runTx
(
args
,
confirmationCb
,
continueCb
,
promptCb
,
cb
)
{
const
self
=
this
async
.
waterfall
([
function
getGasLimit
(
next
)
{
...
...
@@ -350,6 +347,5 @@ UniversalDApp.prototype.runTx = function (args, confirmationCb, continueCb, prom
)
}
],
cb
)
}
}
module
.
exports
=
UniversalDApp
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment