172 lines
5.6 KiB
JavaScript
Raw Normal View History

2019-02-20 15:57:12 -05:00
/*global web3*/
import React from 'react';
2018-01-16 19:17:52 -05:00
import EmbarkJS from 'Embark/EmbarkJS';
2019-02-20 15:57:12 -05:00
import {SimpleStorage, Test, SimpleStorageTest} from '../../embarkArtifacts/contracts';
import config from '../../embarkArtifacts/config/blockchain';
2018-01-16 19:17:52 -05:00
2019-02-20 15:57:12 -05:00
window.SimpleStorageTest = SimpleStorageTest;
2018-01-16 19:17:52 -05:00
import ReactDOM from 'react-dom';
2017-12-13 19:24:20 -05:00
import $ from 'jquery';
2018-01-17 13:16:43 -05:00
import 'bootstrap/dist/css/bootstrap.css';
import 'bootstrap/dist/css/bootstrap-theme.css';
2018-03-02 17:25:56 -05:00
import 'bootstrap/dist/js/bootstrap.min.js';
2017-12-13 17:36:24 -05:00
window.EmbarkJS = EmbarkJS;
window.SimpleStorage = SimpleStorage;
2017-12-20 11:32:11 -05:00
window.Test = Test;
//window.Assert = Assert;
2017-12-13 17:36:24 -05:00
2018-01-16 19:17:52 -05:00
window.React = React;
2017-12-13 17:36:24 -05:00
import './foo.css';
2018-01-17 13:16:43 -05:00
import App from './app.js';
2018-01-16 19:17:52 -05:00
ReactDOM.render(<App />, document.getElementById('root'));
2017-02-09 19:38:02 -05:00
var addToLog = function(id, txt) {
$(id + " .logs").append("<br>" + txt);
};
// ===========================
// Blockchain example
// ===========================
$(document).ready(function() {
2019-02-20 15:57:12 -05:00
EmbarkJS.Blockchain.connect(config, (err) => {
if (err) {
console.error(err);
}
});
2017-12-13 17:36:24 -05:00
console.log([1,2,3].map(v => v + 1));
2017-02-09 19:38:02 -05:00
$("#blockchain button.set").click(function() {
var value = parseInt($("#blockchain input.text").val(), 10);
2017-10-07 21:02:05 -04:00
SimpleStorage.methods.set(value).send({from: web3.eth.defaultAccount, gas: 5300000});
addToLog("#blockchain", "SimpleStorage.methods.set(value).send({from: web3.eth.defaultAccount, gas: 5300000})");
2017-02-09 19:38:02 -05:00
});
$("#blockchain button.get").click(function() {
SimpleStorage.methods.get().call(function(err, value) {
$("#blockchain .value").html(value);
});
addToLog("#blockchain", "SimpleStorage.methods.get(console.log)");
2017-02-09 19:38:02 -05:00
});
});
// ===========================
// Storage (IPFS) example
// ===========================
$(document).ready(function() {
// automatic set if config/storage.json has "enabled": true and "provider": "ipfs"
//EmbarkJS.Storage.setProvider('ipfs',{server: 'localhost', port: '5001'});
2017-02-09 19:38:02 -05:00
2017-10-09 08:59:02 -04:00
$("#storage .error").hide();
2017-12-13 17:36:24 -05:00
//EmbarkJS.Storage.ipfsConnection.version()
// .then(function(){
2017-10-25 06:19:24 -04:00
$("#status-storage").addClass('status-online');
$("#storage-controls").show();
2017-12-13 17:36:24 -05:00
// })
// .catch(function(err) {
// if(err){
// console.log("IPFS Connection Error => " + err.message);
// $("#storage .error").show();
// $("#status-storage").addClass('status-offline');
// $("#storage-controls").hide();
// }
// });
2017-10-09 08:59:02 -04:00
$("#storage button.setIpfsText").click(function() {
var value = $("#storage input.ipfsText").val();
EmbarkJS.Storage.saveText(value).then(function(hash) {
$("span.textHash").html(hash);
$("input.textHash").val(hash);
addToLog("#storage", "EmbarkJS.Storage.saveText('" + value + "').then(function(hash) { })");
})
.catch(function(err) {
if(err){
console.log("IPFS saveText Error => " + err.message);
}
});
});
$("#storage button.loadIpfsHash").click(function() {
var value = $("#storage input.textHash").val();
EmbarkJS.Storage.get(value).then(function(content) {
$("span.ipfsText").html(content);
addToLog("#storage", "EmbarkJS.Storage.get('" + value + "').then(function(content) { })");
})
.catch(function(err) {
if(err){
console.log("IPFS get Error => " + err.message);
}
});
});
$("#storage button.uploadFile").click(function() {
var input = $("#storage input[type=file]");
EmbarkJS.Storage.uploadFile(input).then(function(hash) {
$("span.fileIpfsHash").html(hash);
$("input.fileIpfsHash").val(hash);
addToLog("#storage", "EmbarkJS.Storage.uploadFile($('input[type=file]')).then(function(hash) { })");
})
.catch(function(err) {
if(err){
console.log("IPFS uploadFile Error => " + err.message);
}
});
});
$("#storage button.loadIpfsFile").click(function() {
var hash = $("#storage input.fileIpfsHash").val();
var url = EmbarkJS.Storage.getUrl(hash);
var link = '<a href="' + url + '" target="_blank">' + url + '</a>';
$("span.ipfsFileUrl").html(link);
$(".ipfsImage").attr('src', url);
addToLog("#storage", "EmbarkJS.Storage.getUrl('" + hash + "')");
});
2017-02-09 19:38:02 -05:00
});
// ===========================
// Communication (Whisper) example
// ===========================
$(document).ready(function() {
2017-10-09 08:59:02 -04:00
$("#communication .error").hide();
$("#communication .errorVersion").hide();
if (EmbarkJS.Messages.providerName === 'whisper') {
2019-02-20 15:57:12 -05:00
EmbarkJS.Messages.getWhisperVersion(function(err, _version) {
2017-10-09 08:59:02 -04:00
if (err) {
$("#communication .error").show();
$("#communication-controls").hide();
$("#status-communication").addClass('status-offline');
} else {
EmbarkJS.Messages.setProvider('whisper');
$("#status-communication").addClass('status-online');
}
});
}
$("#communication button.listenToChannel").click(function() {
var channel = $("#communication .listen input.channel").val();
$("#communication #subscribeList").append("<br> subscribed to " + channel + " now try sending a message");
refactor: be consistent with callbacks and promises If a function receives a callback argument then it should not return a promise if the caller's callback will be invoked. Both invoking a callback and returning a promise can lead to at best confusion (in code review and at runtime) and at worst non-deterministic behavior, such as race conditions. Also, a caller supplying a callback may not handle a returned promise, leading to unhandled rejection errors. Refactor all readily identified functions where a callback argument can be supplied but the function returns a promise regardless. Make use of `callbackify` and `promisify` where it made sense to do so during the refactoring. Some callsites of the revised functions may have been accidentally overlooked and still need to be updated. Some functions that take callback arguments may execute them synchronously, at odds with control flow of a returned promise (if a callback wasn't supplied). Such cases should be identified and fixed so that asynchronous behavior is fully consistent whether the caller supplies a callback or receives a promise. Make sure promises that pass control flow to a callback ignore rejections, since those should be handled by the callback. Don't return promise instances unnecessarily from async functions (since they always return promises) and change some functions that return promises to async functions (where it's simple to do so). Whisper was using an ad hoc promise-like `messageEvents` object. However, that object behaved more like an observable, since promises either resolve or reject, and only do so one time. `messageEvents` was also intertwined with callbacks. Replace `messageEvents` with RxJS Observable. `listenTo` now returns Observable instances and callers can subscribe to them. `Blockchain.connect` of embarkjs could suffer from a race condition where tasks associated with `execWhenReady` might be ongoing when `connect`'s returned promise resolves/rejects (or a caller supplied callback fires). Attempt to ensure that returned-promise / supplied-callback control flow proceeds only after `execWhenReady` tasks have finished. The control flow involved is... rather involved, and it could use some further review and refactoring. Bump webpack and the hard-source-plugin for webpack. [util]: https://www.npmjs.com/package/util
2019-02-11 00:08:01 -06:00
EmbarkJS.Messages.listenTo({topic: [channel]}).subscribe(function({data: message}) {
2017-10-09 08:59:02 -04:00
$("#communication #messagesList").append("<br> channel: " + channel + " message: " + message);
});
addToLog("#communication", "EmbarkJS.Messages.listenTo({topic: ['" + channel + "']}).then(function(message) {})");
});
$("#communication button.sendMessage").click(function() {
var channel = $("#communication .send input.channel").val();
var message = $("#communication .send input.message").val();
EmbarkJS.Messages.sendMessage({topic: channel, data: message});
addToLog("#communication", "EmbarkJS.Messages.sendMessage({topic: '" + channel + "', data: '" + message + "'})");
});
2017-02-09 19:38:02 -05:00
});