var $ = require('jquery'); var UniversalDApp = require('./universal-dapp.js'); var web3 = require('./web3-adapter.js'); var queryParams = require('./app/query-params'); var gistHandler = require('./app/gist-handler'); var StorageHandler = require('./app/storage-handler'); var Editor = require('./app/editor'); var Compiler = require('./app/compiler'); // The event listener needs to be registered as early as possible, because the // parent will send the message upon the "load" event. var filesToLoad = null; var loadFilesCallback = function(files) { filesToLoad = files; }; // will be replaced later window.addEventListener("message", function(ev) { if (typeof ev.data == typeof [] && ev.data[0] === "loadFiles") { loadFilesCallback(ev.data[1]); } }, false); var Base64 = require('js-base64').Base64; var run = function() { // ------------------ query params (hash) ---------------- function syncQueryParams() { $('#optimize').attr( 'checked', (queryParams.get().optimize == "true") ); } window.onhashchange = syncQueryParams; syncQueryParams(); // ------------------ gist load ---------------- function loadFiles(files) { for (var f in files) { var key = fileKey(f); var content = files[f].content; if (key in window.localStorage && window.localStorage[key] != content) { var count = ''; var otherKey = key + count; while ((key + count) in window.localStorage) count = count - 1; window.localStorage[key + count] = window.localStorage[key]; } window.localStorage[key] = content; } editor.setCacheFile(fileKey(Object.keys(files)[0])); updateFiles(); } var loadingFromGist = gistHandler.handleLoad(function(gistId) { $.ajax({ url: 'https://api.github.com/gists/'+gistId, jsonp: 'callback', dataType: 'jsonp', success: function(response) { if (response.data) { if (!response.data.files) { alert( "Gist load error: " + response.data.message ); return; } loadFiles(response.data.files); } } }); }); loadFilesCallback = function(files) { loadFiles(files); }; if (filesToLoad !== null) loadFiles(filesToLoad); // ----------------- storage -------------------- var SOL_CACHE_FILE_PREFIX = 'sol-cache-file-'; var storageHandler = new StorageHandler(updateFiles, SOL_CACHE_FILE_PREFIX); window.syncStorage = storageHandler.sync; storageHandler.sync(); // ----------------- editor ---------------------- var editor = new Editor(loadingFromGist, SOL_CACHE_FILE_PREFIX); // ----------------- tabbed menu ------------------- $('#options li').click(function(ev){ var $el = $(this); var match = /[a-z]+View/.exec( $el.get(0).className ); if (!match) return; var cls = match[0]; if (!$el.hasClass('active')) { $el.parent().find('li').removeClass('active'); $('#optionViews').attr('class', '').addClass(cls); $el.addClass('active'); } else { $el.removeClass('active'); $('#optionViews').removeClass(cls); } }); // ----------------- execution context ------------- var $vmToggle = $('#vm'); var $web3Toggle = $('#web3'); var $web3endpoint = $('#web3Endpoint'); if (web3.providers && web3.currentProvider instanceof web3.providers.IpcProvider) $web3endpoint.val('ipc'); var executionContext = 'vm'; $vmToggle.get(0).checked = true; $vmToggle.on('change', executionContextChange ); $web3Toggle.on('change', executionContextChange ); $web3endpoint.on('change', function() { setProviderFromEndpoint(); if (executionContext == 'web3') compiler.compile(); }); function executionContextChange (ev) { if (ev.target.value == 'web3' && !confirm("Are you sure you want to connect to a local ethereum node?") ) { $vmToggle.get(0).checked = true; executionContext = 'vm'; } else { executionContext = ev.target.value; setProviderFromEndpoint(); } compiler.compile(); } function setProviderFromEndpoint() { var endpoint = $web3endpoint.val(); if (endpoint == 'ipc') web3.setProvider(new web3.providers.IpcProvider()); else web3.setProvider(new web3.providers.HttpProvider(endpoint)); } // ------------------ gist publish -------------- var packageFiles = function() { var files = {}; var filesArr = editor.getFiles(); for (var f in filesArr) { files[fileNameFromKey(filesArr[f])] = { content: localStorage[filesArr[f]] }; } return files; }; $('#gist').click(function(){ if (confirm("Are you sure you want to publish all your files anonymously as a public gist on github.com?")) { var files = packageFiles(); var description = "Created using browser-solidity: Realtime Ethereum Contract Compiler and Runtime. \n Load this file by pasting this gists URL or ID at https://ethereum.github.io/browser-solidity/#version=" + queryParams.get().version + "&optimize="+ queryParams.get().optimize +"&gist="; $.ajax({ url: 'https://api.github.com/gists', type: 'POST', data: JSON.stringify({ description: description, public: true, files: files }) }).done(function(response) { if (response.html_url && confirm("Created a gist at " + response.html_url + " Would you like to open it in a new window?")) { window.open( response.html_url, '_blank' ); } }); } }); $('#copyOver').click(function(){ var target = prompt( "To which other browser-solidity instance do you want to copy over all files?", "https://ethereum.github.io/browser-solidity/" ); if (target === null) return; var files = packageFiles(); var iframe = $('