diff --git a/src/app/ui/landing-page/landing-page.js b/src/app/ui/landing-page/landing-page.js index 9c918d9099..891f9efac7 100644 --- a/src/app/ui/landing-page/landing-page.js +++ b/src/app/ui/landing-page/landing-page.js @@ -15,7 +15,6 @@ let css = csjs` max-width : 300px; min-height : 200px; background-color: var(--light); - font-family : "Lucida Console", Monaco, monospace; } .landingPage { height : 100%; @@ -41,23 +40,70 @@ let css = csjs` width : 100%; font-size : xx-large; align-self : center; - } .text { cursor: pointer; font-weight: normal; max-width: 300px; user-select: none; + color: var(--primary); } .text:hover { - font-weight: bold; + text-decoration: underline; + } + .homeContainer { + user-select:none; + } + .jumbotronContainer { + /* margin: 50px 60px 0; */ + /* width: 80%; */ + } + .thisJumboton { + padding: 2.5rem 5rem; + /* display: flex;*/ + /* justify-content: space-between;*/ + margin-bottom: 4rem; + } + .hpLogoContainer { + margin:30px; + padding-right: 90px; + } + .jumboBtnContainer { + float: left; + padding-top: 15px; + } + .headlineContainer { + float: left; + padding-top: 17px; + margin: 0 100px 0 70px; + } + .hpSections { + margin: 0 60px; + } + .solidityBtn { + margin-right: 40px; + } + .labelIt { + margin-bottom: 0; + } + .seeAll { + margin-top: 7px; + } + .importFrom p { + margin-right: 10px; } + .logoContainer { + margin-top: 7px; + float: left; + } + .logoContainer img{ + height: 65px; + } + } ` -import { defaultWorkspaces } from './workspace' import { BaseApi } from 'remix-plugin' -import Section from './section' const profile = { displayName: 'Home', @@ -74,7 +120,10 @@ export class LandingPage extends BaseApi { constructor (appManager, appStore) { super(profile) this.appStore = appStore - this.sections = [] + this.appManager = appManager + } + + render () { let load = function (item) { let compilerImport = new CompilerImport() let fileProviders = globalRegistry.get('fileproviders').api @@ -96,162 +145,124 @@ export class LandingPage extends BaseApi { } }) } - let fileExplorer = globalRegistry.get('fileexplorer/browser').api - var actionsStart = [ - { label: 'New file', - type: 'callback', - payload: () => { - fileExplorer.createNewFile() - } - }, - { - // Open a file - label: yo` - - `, - type: `callback`, - description: ``, - payload: () => {} - }, - { label: 'Import from Gist', - type: `callback`, - description: ``, - payload: () => { - let app = globalRegistry.get('app').api - app.loadFromGist({gist: ''}) - } - }, - { label: 'Import from GitHub', - type: `callback`, - description: ``, - payload: () => { - load('URL') - } - }, - { label: 'Import from Swarm', - type: `callback`, - description: ``, - payload: () => { load('bzz-raw URL') } - }, - { label: 'Import from IPFS', - type: `callback`, - description: ``, - payload: () => { load('IPFS URL') } - }, - { label: 'Connect to localhost', - type: `callback`, - description: ``, - payload: () => { - appManager.ensureActivated('remixd') - } - } - ] - - var actionsResources = [ - { label: 'Remix documentation', type: `link`, description: ``, payload: `https://remix.readthedocs.io/en/latest/#` }, - { label: 'Medium posts', type: `link`, description: ``, payload: `https://medium.com/remix-ide` }, - { label: 'Gitter channel', type: `link`, description: ``, payload: `https://gitter.im/ethereum/remix` } - ] - - var sectionStart = new Section('Start', actionsStart) - let sectionResources = new Section('Resources', actionsResources) - - this.sectionWorkspaceMain = [] - // this.sectionWorkspaceOthers = [] - defaultWorkspaces(appManager).forEach((workspace) => { - if (workspace.isMain) { - this.sectionWorkspaceMain.push({ - label: workspace.title, - type: 'callback', - description: workspace.description, - payload: () => { workspace.activate() } - }) - } else { - /* this.sectionWorkspaceOthers.push({ - label: workspace.title, - type: 'callback', - description: workspace.description, - payload: () => { workspace.activate() } - }) */ - } - }) - - this.sections.push(sectionStart) - this.sections.push(sectionResources) - } - - render () { let logo = '' - let totalLook = yo` -
-
- ` - let main = yo`
` - for (let i = 0; i < this.sectionWorkspaceMain.length; i++) { - main.appendChild(yo` - - ${this.sectionWorkspaceMain[i].label} - - `) - } - let icon = '' + let learnMore = () => { tooltip('not implemented') } - main.appendChild(yo` - - Check out all plugins here - - - `) + let closeAll = () => { + this.appStore.getActives() + .filter(({profile}) => !profile.required) + .forEach((profile) => { this.appManager.deactivateOne(profile.name) }) + } + let startSolidity = () => { + closeAll() + this.appManager.ensureActivated('solidity') + this.appManager.ensureActivated('run') + this.appManager.ensureActivated('solidityStaticAnalysis') + this.appManager.ensureActivated('solidityUnitTesting') + globalRegistry.get('filemanager').api.switchFile() + globalRegistry.get('verticalicon').api.select('solidity') + } + let startVyper = () => { + closeAll() + this.appManager.ensureActivated('vyper') + this.appManager.ensureActivated('run') + globalRegistry.get('filemanager').api.switchFile() + globalRegistry.get('verticalicon').api.select('vyper') + } - /* let others = yo`
` - for (let i = 0; i < this.sectionWorkspaceOthers.length; i++) { - others.appendChild(yo` - - ${this.sectionWorkspaceOthers[i].label} - - `) - } */ + let startPipeline = () => { + this.appManager.ensureActivated('solidity') + this.appManager.ensureActivated('pipeline') + this.appManager.ensureActivated('run') + } + let startDebugger = () => { + this.appManager.ensureActivated('debugger') + globalRegistry.get('verticalicon').api.select('debugger') + } + let startPluginManager = () => { + this.appManager.ensureActivated('pluginManager') + globalRegistry.get('verticalicon').api.select('pluginManager') + } - let docs = yo`
` - for (let i = 0; i < this.sections.length; i++) { - docs.appendChild(yo` -
- ${this.sections[i].render()} -
- `) + let createNewFile = () => { + let fileExplorer = globalRegistry.get('fileexplorer/browser').api + fileExplorer.createNewFile() + } + let connectToLocalhost = () => { + this.appManager.ensureActivated('remixd') + } + let importFromGist = () => { + let app = globalRegistry.get('app').api + app.loadFromGist({gist: ''}) } - totalLook.appendChild(yo` -
-
-
-
- -
-
Workspaces
-

${main}

-
-
+ let container = yo`
+
+
+
+ remix logo +
+
+

The new layout has arrived

+
+
+ +
+
+
+
+
+
+

Environments

- { tooltip(' not implemented yet :P ') }}>Get Started -
+ + +
+
+
+

File

+

{ createNewFile() }}>New File

+

+ +

+

{ connectToLocalhost() }}>Connect to Localhost

+

Import From:

+
+ + + + +
+
+
+
+
+

Featured Plugins

+

{ startPipeline() }}>Pipeline

+

{ startDebugger() }}>Debugger

+

-
- ${docs} + -
-
- `) +
+
+
` - return totalLook + return container } } diff --git a/src/app/ui/modal-dialog-custom.js b/src/app/ui/modal-dialog-custom.js index f793a892f6..16803b32ab 100644 --- a/src/app/ui/modal-dialog-custom.js +++ b/src/app/ui/modal-dialog-custom.js @@ -66,7 +66,7 @@ module.exports = { function prompt (title, text, hidden, inputValue, ok, cancel, focus) { if (!inputValue) inputValue = '' var type = hidden ? 'password' : 'text' - var input = yo`` + var input = yo`` modal(title, yo`
${text}
${input}
`, { fn: () => { if (typeof ok === 'function') ok(document.getElementById('prompt_text').value) } diff --git a/src/lib/gist-handler.js b/src/lib/gist-handler.js index b66db8ef22..f99001b1ff 100644 --- a/src/lib/gist-handler.js +++ b/src/lib/gist-handler.js @@ -12,7 +12,7 @@ function GistHandler (_window) { var gistId if (params['gist'] === '') { loadingFromGist = true - modalDialogCustom.prompt(null, 'Enter the URL or ID of the Gist you would like to load.', null, (target) => { + modalDialogCustom.prompt(null, 'Enter the ID of the Gist you would like to load.', null, (target) => { if (target !== '') { gistId = getGistId(target) if (gistId) {