mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-17 09:11:38 +00:00
991d958436
[PR 1318][PR1318] introduces a monorepo member that's used as a DApp dependency, but the present arrangement whereby `test_dapps/` is an embedded monorepo makes it difficult to develop and test such packages in tandem with changes to `test_dapps/packages/*`. Reorganize `test_dapps/*` as members of the root monorepo and make various adjustments accordingly. This makes it easy to develop test dapps and any packages they depend on simultaneously, but we lose the CI/QA arrangement where test dapps are run with an embark installed from fresh tarballs. That arrangement, which is quite worthwhile as a means to detect problems arising from transitive dependencies as soon as possible, will be re-introduced in another PR, possibly involving an auxiliary repository such as embark-framework/dapp-bin. Since the `package.json` `"test"` scripts of `test_dapps/*` are now kicked off as part of `yarn test` in the root, and since port allocation isn't fully dynamic, it's important to run `yarn test` with `lerna run`'s `--concurrency=1` option. For the same reasons, the root `ci` and `qa` scripts are similarly restricted. In the future, this setup can be refactored and improved, along with use of `lerna run`'s `--since` option to increase testing efficiency in CI. [PR1318]: https://github.com/embark-framework/embark/pull/1318
176 lines
5.8 KiB
JavaScript
176 lines
5.8 KiB
JavaScript
/*globals $, SimpleStorage, document*/
|
|
|
|
import React, { Component } from 'react';
|
|
import EmbarkJS from 'Embark/EmbarkJS';
|
|
import SimpleStorage from 'Embark/contracts/SimpleStorage';
|
|
import Test from 'Embark/contracts/Test';
|
|
//import Assert from 'Embark/contracts/Assert';
|
|
|
|
import SimpleStorageTest from 'Embark/contracts/SimpleStorageTest';
|
|
window.SimpleStorageTest = SimpleStorageTest
|
|
|
|
import ReactDOM from 'react-dom';
|
|
|
|
//import $ from './_vendor/jquery.min';
|
|
import $ from 'jquery';
|
|
//import 'bootstrap';
|
|
import 'bootstrap/dist/css/bootstrap.css';
|
|
import 'bootstrap/dist/css/bootstrap-theme.css';
|
|
//import 'bootstrap/dist/css/bootstrap.min.css';
|
|
import 'bootstrap/dist/js/bootstrap.min.js';
|
|
|
|
//import 'react-bootstrap/dist/react-bootstrap.min.js';
|
|
|
|
import { Navbar, Jumbotron, Button } from 'react-bootstrap';
|
|
|
|
window.EmbarkJS = EmbarkJS;
|
|
window.SimpleStorage = SimpleStorage;
|
|
window.Test = Test;
|
|
//window.Assert = Assert;
|
|
|
|
window.React = React;
|
|
|
|
import './foo.css';
|
|
|
|
import App from './app.js';
|
|
|
|
ReactDOM.render(<App />, document.getElementById('root'));
|
|
|
|
var addToLog = function(id, txt) {
|
|
$(id + " .logs").append("<br>" + txt);
|
|
};
|
|
|
|
// ===========================
|
|
// Blockchain example
|
|
// ===========================
|
|
$(document).ready(function() {
|
|
console.log([1,2,3].map(v => v + 1));
|
|
|
|
$("#blockchain button.set").click(function() {
|
|
var value = parseInt($("#blockchain input.text").val(), 10);
|
|
|
|
SimpleStorage.methods.set(value).send({from: web3.eth.defaultAccount, gas: 5300000});
|
|
addToLog("#blockchain", "SimpleStorage.methods.set(value).send({from: web3.eth.defaultAccount, gas: 5300000})");
|
|
});
|
|
|
|
$("#blockchain button.get").click(function() {
|
|
SimpleStorage.methods.get().call(function(err, value) {
|
|
$("#blockchain .value").html(value);
|
|
});
|
|
addToLog("#blockchain", "SimpleStorage.methods.get(console.log)");
|
|
});
|
|
|
|
});
|
|
|
|
// ===========================
|
|
// 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'});
|
|
|
|
$("#storage .error").hide();
|
|
//EmbarkJS.Storage.ipfsConnection.version()
|
|
// .then(function(){
|
|
$("#status-storage").addClass('status-online');
|
|
$("#storage-controls").show();
|
|
// })
|
|
// .catch(function(err) {
|
|
// if(err){
|
|
// console.log("IPFS Connection Error => " + err.message);
|
|
// $("#storage .error").show();
|
|
// $("#status-storage").addClass('status-offline');
|
|
// $("#storage-controls").hide();
|
|
// }
|
|
// });
|
|
|
|
$("#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 + "')");
|
|
});
|
|
|
|
});
|
|
|
|
// ===========================
|
|
// Communication (Whisper) example
|
|
// ===========================
|
|
$(document).ready(function() {
|
|
|
|
$("#communication .error").hide();
|
|
$("#communication .errorVersion").hide();
|
|
if (EmbarkJS.Messages.providerName === 'whisper') {
|
|
EmbarkJS.Messages.getWhisperVersion(function(err, version) {
|
|
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");
|
|
EmbarkJS.Messages.listenTo({topic: [channel]}).then(function(message) {
|
|
$("#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 + "'})");
|
|
});
|
|
|
|
});
|