|
|
|
@ -22,9 +22,7 @@ var SharedFolder = require('./app/files/shared-folder') |
|
|
|
|
var Config = require('./config') |
|
|
|
|
var Renderer = require('./app/ui/renderer') |
|
|
|
|
var executionContext = require('./execution-context') |
|
|
|
|
var FilePanel = require('./app/panels/file-panel') |
|
|
|
|
var EditorPanel = require('./app/panels/editor-panel') |
|
|
|
|
var RighthandPanel = require('./app/panels/righthand-panel') |
|
|
|
|
var examples = require('./app/editor/example-contracts') |
|
|
|
|
var modalDialogCustom = require('./app/ui/modal-dialog-custom') |
|
|
|
|
var TxLogger = require('./app/execution/txLogger') |
|
|
|
@ -36,27 +34,16 @@ var NotPersistedExplorer = require('./app/files/NotPersistedExplorer') |
|
|
|
|
var toolTip = require('./app/ui/tooltip') |
|
|
|
|
var TransactionReceiptResolver = require('./transactionReceiptResolver') |
|
|
|
|
|
|
|
|
|
const CompilerAbstract = require('./app/compiler/compiler-abstract') |
|
|
|
|
// const PluginManager = require('./app/plugin/pluginManager')
|
|
|
|
|
|
|
|
|
|
// var IconPanel = require('./app/panels/left-icon-panel')
|
|
|
|
|
const PluginManagerComponent = require('./app/components/plugin-manager-component') |
|
|
|
|
const PluginManagerApi = require('./app/components/plugin-manager-api') |
|
|
|
|
|
|
|
|
|
const VerticalIconsComponent = require('./app/components/vertical-icons-component') |
|
|
|
|
const VerticalIconsApi = require('./app/components/vertical-icons-api') |
|
|
|
|
// var VerticalIconsProfile = require('./app/panels/vertical-icons-profile')
|
|
|
|
|
|
|
|
|
|
const SwapPanelComponent = require('./app/component/swap-panel-component') |
|
|
|
|
const SwapPanelComponent = require('./app/component/swap-panel-api') |
|
|
|
|
|
|
|
|
|
const CompileTab = require('./app/tabs/compile-tab') |
|
|
|
|
const SettingsTab = require('./app/tabs/settings-tab') |
|
|
|
|
const AnalysisTab = require('./app/tabs/analysis-tab') |
|
|
|
|
const DebuggerTab = require('./app/tabs/debugger-tab') |
|
|
|
|
const SupportTab = require('./app/tabs/support-tab') |
|
|
|
|
const TestTab = require('./app/tabs/test-tab') |
|
|
|
|
const RunTab = require('./app/tabs/run-tab') |
|
|
|
|
const SwapPanelComponent = require('./app/components/swap-panel-component') |
|
|
|
|
const SwapPanelApi = require('./app/components/swap-panel-api') |
|
|
|
|
|
|
|
|
|
const appManager = require('remix-plugin').appManager |
|
|
|
|
const AppManager = require('remix-plugin').AppManager |
|
|
|
|
|
|
|
|
|
var styleGuide = require('./app/ui/styles-guide/theme-chooser') |
|
|
|
|
var styles = styleGuide.chooser() |
|
|
|
@ -81,16 +68,18 @@ var css = csjs` |
|
|
|
|
height : 100vh; |
|
|
|
|
overflow : hidden; |
|
|
|
|
} |
|
|
|
|
.centerpanel { |
|
|
|
|
.mainpanel { |
|
|
|
|
background-color : ${styles.colors.transparent}; |
|
|
|
|
display : flex; |
|
|
|
|
flex-direction : column; |
|
|
|
|
position : absolute; |
|
|
|
|
top : 0; |
|
|
|
|
bottom : 0; |
|
|
|
|
left : 450px; |
|
|
|
|
overflow : hidden; |
|
|
|
|
width : 800px; |
|
|
|
|
} |
|
|
|
|
.leftpanel { |
|
|
|
|
.iconpanel { |
|
|
|
|
background-color : ${styles.leftPanel.backgroundColor_Panel}; |
|
|
|
|
display : flex; |
|
|
|
|
flex-direction : column; |
|
|
|
@ -99,16 +88,17 @@ var css = csjs` |
|
|
|
|
bottom : 0; |
|
|
|
|
left : 0; |
|
|
|
|
overflow : hidden; |
|
|
|
|
width : 50px; |
|
|
|
|
} |
|
|
|
|
.rightpanel { |
|
|
|
|
background-color : ${styles.rightPanel.backgroundColor_Panel}; |
|
|
|
|
.swappanel { |
|
|
|
|
display : flex; |
|
|
|
|
flex-direction : column; |
|
|
|
|
position : absolute; |
|
|
|
|
top : 0; |
|
|
|
|
right : 0; |
|
|
|
|
left : 50px; |
|
|
|
|
bottom : 0; |
|
|
|
|
overflow : hidden; |
|
|
|
|
width : 400px; |
|
|
|
|
} |
|
|
|
|
.highlightcode { |
|
|
|
|
position:absolute; |
|
|
|
@ -176,18 +166,18 @@ class App { |
|
|
|
|
self.data = { |
|
|
|
|
_layout: { |
|
|
|
|
right: { |
|
|
|
|
offset: self._components.config.get('right-offset') || 400, |
|
|
|
|
offset: 400, |
|
|
|
|
show: true |
|
|
|
|
}, // @TODO: adapt sizes proportionally to browser window size
|
|
|
|
|
left: { |
|
|
|
|
offset: self._components.config.get('left-offset') || 200, |
|
|
|
|
offset: 200, |
|
|
|
|
show: true |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
_adjustLayout (direction, delta) { |
|
|
|
|
var self = this |
|
|
|
|
/*var self = this |
|
|
|
|
var layout = self.data._layout[direction] |
|
|
|
|
if (layout) { |
|
|
|
|
if (delta === undefined) { |
|
|
|
@ -203,10 +193,11 @@ class App { |
|
|
|
|
self._view.swappanel.style.width = delta + 'px' |
|
|
|
|
self._view.mainpanel.style.left = delta + 'px' |
|
|
|
|
} |
|
|
|
|
// if (direction === 'right') {
|
|
|
|
|
// self._view.mainpanel.style.width = delta + 'px'
|
|
|
|
|
// self._view.swappanel.style.right = delta + 'px'
|
|
|
|
|
// }
|
|
|
|
|
if (direction === 'right') { |
|
|
|
|
self._view.mainpanel.style.width = delta + 'px' |
|
|
|
|
self._view.swappanel.style.right = delta + 'px' |
|
|
|
|
} |
|
|
|
|
*/ |
|
|
|
|
} |
|
|
|
|
init () { |
|
|
|
|
var self = this |
|
|
|
@ -218,7 +209,7 @@ class App { |
|
|
|
|
if (self._view.el) return self._view.el |
|
|
|
|
// not resizable
|
|
|
|
|
self._view.iconpanel = yo` |
|
|
|
|
<div id="icon-panel" class=${css.iconpanel} style="width: 50px;"> |
|
|
|
|
<div id="icon-panel" class=${css.iconpanel}> |
|
|
|
|
${''} |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
@ -232,7 +223,7 @@ class App { |
|
|
|
|
|
|
|
|
|
// handle the editor + terminal
|
|
|
|
|
self._view.mainpanel = yo` |
|
|
|
|
<div id="editor-container" class=${css.centerpanel}> |
|
|
|
|
<div id="editor-container" class=${css.mainpanel}> |
|
|
|
|
${''} |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
@ -245,7 +236,7 @@ class App { |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
// INIT
|
|
|
|
|
self._adjustLayout('left', self.data._layout.left.offset) |
|
|
|
|
// self._adjustLayout('left', self.data._layout.left.offset)
|
|
|
|
|
// self._adjustLayout('right', self.data._layout.right.offset)
|
|
|
|
|
return self._view.el |
|
|
|
|
} |
|
|
|
@ -353,7 +344,7 @@ Please make a backup of your contracts and start using http://remix.ethereum.org |
|
|
|
|
resolveReceipt: function (tx, cb) { |
|
|
|
|
transactionReceiptResolver.resolve(tx, cb) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
}, |
|
|
|
|
event: { |
|
|
|
|
udapp: udapp.event |
|
|
|
|
}}) |
|
|
|
@ -381,103 +372,43 @@ Please make a backup of your contracts and start using http://remix.ethereum.org |
|
|
|
|
var fileManager = self._components.fileManager |
|
|
|
|
registry.put({api: fileManager, name: 'filemanager'}) |
|
|
|
|
|
|
|
|
|
// ----------------- app manager ----------------------------
|
|
|
|
|
const VerticalIconsProfile = { |
|
|
|
|
type: 'verticalIcons', |
|
|
|
|
methods: ['addIcon', 'removeIcon'], |
|
|
|
|
} |
|
|
|
|
// ----------------- Renderer -----------------
|
|
|
|
|
var renderer = new Renderer() |
|
|
|
|
registry.put({api: renderer, name: 'renderer'}) |
|
|
|
|
|
|
|
|
|
const SwapPanelProfile = { |
|
|
|
|
type: 'swapPanel', |
|
|
|
|
methods: ['addView', 'showContent'], |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// ----------------- app manager ----------------------------
|
|
|
|
|
const PluginManagerProfile = { |
|
|
|
|
type: 'pluginManager', |
|
|
|
|
methods: [], |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
const FileManagerProfile = { |
|
|
|
|
type: 'fileManager', |
|
|
|
|
methods: [], |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
const SettingsProfile = { |
|
|
|
|
type: 'settings', |
|
|
|
|
methods: [], |
|
|
|
|
methods: [] |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
const appManager = new appManager() |
|
|
|
|
const appManager = new AppManager({modules: [],plugins : []}) |
|
|
|
|
|
|
|
|
|
const swapPanelComponent = new SwapPanelComponent() |
|
|
|
|
const pluginManagerComponent = new PluginManagerComponent(appManager) |
|
|
|
|
const verticalIconComponent = new VerticalIconsComponent(appManager) |
|
|
|
|
|
|
|
|
|
const swapPanelApi = new SwapPanelApi(swapPanelComponent) |
|
|
|
|
const verticalIconApi = new VerticalsIconApi(verticalIconComponent) |
|
|
|
|
const pluginManagerAPI = new pluginManagerAPI(pluginManagerComponent) |
|
|
|
|
|
|
|
|
|
// All Plugins and Modules are registered in the contructor
|
|
|
|
|
// You cannot add module after
|
|
|
|
|
appManager.init({ |
|
|
|
|
// Module should be activated by default
|
|
|
|
|
modules: [ |
|
|
|
|
{ json: VerticalIconsProfile, api: verticalIconApi }, |
|
|
|
|
{ json: SwapPanelProfile, api: swapPanelApi }, |
|
|
|
|
{ json: PluginManagerProfile, api: pluginManagerApi }, |
|
|
|
|
{ json: FileManagerProfile, api: self._components.filePanel }, |
|
|
|
|
], |
|
|
|
|
// Plugins need to be activated
|
|
|
|
|
plugins: [], |
|
|
|
|
options: { |
|
|
|
|
bootstrap: 'pluginManager' |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
self._components.filePanel = new FilePanel() |
|
|
|
|
registry.put({api: self._components.filePanel, name: 'filepanel'}) |
|
|
|
|
swapPanelApi.addView('File', self._components.filePanel.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const compileTab = new CompileTab(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Compile', compileTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const testTab = new TestTab(self._components.registry, compileTab) |
|
|
|
|
swapPanelApi.addView('Test', testTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const runTab = new RunTab(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Run', runTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const analysisTab = new AnalysisTab(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Analysis', analysisTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const debuggerTab = new DebuggerTab(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Debugger', debuggerTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
|
|
|
|
|
const supportTab = new SupportTab(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Support', supportTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
const pluginManagerComponent = new PluginManagerComponent() |
|
|
|
|
registry.put({api: pluginManagerComponent.proxy(), name: 'pluginmanager'}) |
|
|
|
|
|
|
|
|
|
const settings = new SettingsTab()(self._components.registry) |
|
|
|
|
swapPanelApi.addView('Settings', settingsTab.render()) |
|
|
|
|
verticalIconApi.addIcon('') |
|
|
|
|
self._components.editorpanel.init() |
|
|
|
|
self._components.fileManager.init()
|
|
|
|
|
|
|
|
|
|
const verticalIconComponent = new VerticalIconsComponent() |
|
|
|
|
|
|
|
|
|
self._components.iconpanel.appendChild(verticalIconComponent.render()) |
|
|
|
|
self._components.iconpanel.event.register('resize', delta => self._adjustLayout('left', delta)) |
|
|
|
|
const swapPanelApi = new SwapPanelApi(swapPanelComponent, verticalIconComponent, pluginManagerComponent) |
|
|
|
|
const verticalIconsApi = new VerticalIconsApi(verticalIconComponent, pluginManagerComponent) |
|
|
|
|
const pluginManagerAPI = new PluginManagerApi(pluginManagerComponent) |
|
|
|
|
|
|
|
|
|
self._components.swappanel.appendChild(swapPanelComponent.render()) |
|
|
|
|
self._components.swappanel.event.register('resize', delta => self._adjustLayout('center', delta)) |
|
|
|
|
self._view.mainpanel.appendChild(self._components.editorpanel.render()) |
|
|
|
|
self._view.iconpanel.appendChild(verticalIconComponent.render()) |
|
|
|
|
self._view.swappanel.appendChild(swapPanelComponent.render()) |
|
|
|
|
|
|
|
|
|
self._components.editorpanel.init() |
|
|
|
|
self._components.fileManager.init() |
|
|
|
|
pluginManagerComponent.initDefault() |
|
|
|
|
verticalIconComponent.select('FilePanel') |
|
|
|
|
// appManager.init(pluginManagerAPI)
|
|
|
|
|
|
|
|
|
|
self._components.editorpanel.event.register('resize', direction => self._adjustLayout(direction)) |
|
|
|
|
self._view.centerpanel.appendChild(self._components.editorpanel.render()) |
|
|
|
|
pluginManagerAPI.init({ |
|
|
|
|
modules: [], |
|
|
|
|
plugins: [] |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
// The event listener needs to be registered as early as possible, because the
|
|
|
|
|
// parent will send the message upon the "load" event.
|
|
|
|
@ -500,10 +431,6 @@ Please make a backup of your contracts and start using http://remix.ethereum.org |
|
|
|
|
self.loadFiles(filesToLoad) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// ----------------- Renderer -----------------
|
|
|
|
|
var renderer = new Renderer() |
|
|
|
|
registry.put({api: renderer, name: 'renderer'}) |
|
|
|
|
|
|
|
|
|
var txLogger = new TxLogger() // eslint-disable-line
|
|
|
|
|
|
|
|
|
|
var queryParams = new QueryParams() |
|
|
|
|